Luigi Buglione
Software Product Quality: Some Thoughts about its Evolution and Perspectives
From the mid ‘70s on, a plenty of attention was devoted to evaluate and measure software quality. As Tom Demarco said: “you cannot control what you cannot measure”. But coming back, it’s also true that “you cannot measure what you cannot define” and again “you cannot define what you don’t know”. Thus, moving from definition is the priority for any activity and creates also measures from a common, shared definition. The FCM (Factor-Criteria-Model) was the first ‘quality model’ in 1977 by the US Air Force trying to state a “three-tier” model for defining what quality could be for a software product. Later, Boehm (1978) and ISO (1991) with its first version of the 9126 model (now evolved into the 25010:2011 one, in the SQuARE standard series, did the same exercise. Again, maybe less known, other models and taxonomies have been created and proposed in the technical literature (e.g. FURPS+, ECSS-E-10A, ISO 21351:2005, etc.) for the same purpose. What a very few do is to understand (and deal with, accordingly) that ‘quality’ means ‘non-functional’ (or at least, a large part of the ISO definition of NFR – Non-functional Requirements). From a measurement perspective it means to deal with a very (relative) unexplored area, with a plenty of possible developments. In fact, a FUR (Functional User Requirement) is something about the ‘what’ a software can do by its functionalities and FPA (Function Point Analysis) - whatever the variant adopted – in a single number tries to relate a sizing unit expressing such ‘functional dimension’. Dealing with NFR and Software Quality is a very complex work, because of the large number of attributes composing ‘quality’. Each category in one of the aforementioned quality models could be a separate issue as well as now is the ‘functionality’ one. Taking into account several attributes at the same time and determining a ‘quality profile’ for a certain type of software will be one of the next decade challenges. Estimators will need to understand better and better which NFR-related (quality) measures to include (at least 2+ ones) as independent proxies in estimation models, allowing estimators to reduce MRE (Mean Relative Error) figures as much as possible, saving project resources and improving the overall project value for its stakeholders. In order to do that, this paper will try to discuss from an evolutionary perspective what software quality has been, is and should/could be perceived and defined during next years, by a measurement perspective.