Recovering architectural assumptions

  • Authors:
  • Ronny Roeller;Patricia Lago;Hans van Vliet

  • Affiliations:
  • Computer Science Department, Vrije Universiteit, De Boelelaan 1081a, 1081 HV Amsterdam, The Netherlands;Computer Science Department, Vrije Universiteit, De Boelelaan 1081a, 1081 HV Amsterdam, The Netherlands;Computer Science Department, Vrije Universiteit, De Boelelaan 1081a, 1081 HV Amsterdam, The Netherlands

  • Venue:
  • Journal of Systems and Software
  • Year:
  • 2006

Quantified Score

Hi-index 0.00

Visualization

Abstract

During the creation of a software architecture, the architects and stakeholders take a lot of decisions. Many of these decisions can be directly related to functional or quality requirements. Some design decisions, though, are more or less arbitrarily made on the fly because of personal experience, domain knowledge, budget constraints, available expertise, and the like. These decisions, as well as the reasons for those decisions, are often not explicit upfront. They are implicit, and usually remain undocumented. We call them assumptions. There is no accepted way to document assumptions, and the relation between the software architecture and these assumptions easily gets lost, becomes hidden in the girders of the architecture. They are rediscovered at a later stage, when the software evolves and assumptions become invalid or new assumptions contradict earlier ones. In this paper, we develop a method to recover such assumptions from an existing software product. We illustrate the method by applying it to a commercial software product, and show how the results can help assess the evolutionary capabilities of its architecture.