TY - JOUR
T1 - An investigation into the functional form of the size-defect relationship for software modules
AU - Koru, A. Güneş
AU - Zhang, Dongsong
AU - El Emam, Khaled
AU - Liu, Hongfang
PY - 2009
Y1 - 2009
N2 - The importance of the relationship between size and defect proneness of software modules is well recognized. Understanding the nature of that relationship can facilitate various development decisions related to prioritization of quality assurance activities. Overall, the previous research only drew a general conclusion that there was a monotonically increasing relationship between module size and defect proneness. In this study, we analyzed class-level size and defect data in order to increase our understanding of this crucial relationship. In order to obtain validated and more generalizable results, we studied four large-scale object-oriented products, Mozilla, Cn3d, JBoss, and Eclipse. Our results consistently revealed a significant effect of size on defect proneness; however, contrary to common intuition, the size-defect relationship took a logarithmic form, indicating that smaller classes were proportionally more problematic than larger classes. Therefore, practitioners should consider giving higher priority to smaller modules when planning focused quality assurance activities with limited resources. For example, in Mozilla and Eclipse, an inspection strategy investing 80-25; of available resources on 100-LOC classes and the rest on 1,000-LOC classes would be more than twice as cost effective as the opposite strategy. These results should be immediately useful to guide focused quality assurance activities in large-scale software projects.
AB - The importance of the relationship between size and defect proneness of software modules is well recognized. Understanding the nature of that relationship can facilitate various development decisions related to prioritization of quality assurance activities. Overall, the previous research only drew a general conclusion that there was a monotonically increasing relationship between module size and defect proneness. In this study, we analyzed class-level size and defect data in order to increase our understanding of this crucial relationship. In order to obtain validated and more generalizable results, we studied four large-scale object-oriented products, Mozilla, Cn3d, JBoss, and Eclipse. Our results consistently revealed a significant effect of size on defect proneness; however, contrary to common intuition, the size-defect relationship took a logarithmic form, indicating that smaller classes were proportionally more problematic than larger classes. Therefore, practitioners should consider giving higher priority to smaller modules when planning focused quality assurance activities with limited resources. For example, in Mozilla and Eclipse, an inspection strategy investing 80-25; of available resources on 100-LOC classes and the rest on 1,000-LOC classes would be more than twice as cost effective as the opposite strategy. These results should be immediately useful to guide focused quality assurance activities in large-scale software projects.
KW - Measurement applied to SQA and V&V
KW - Open-source software
KW - Planning for SQA and V&V
KW - Product metrics
KW - Size-defect relationship
KW - Software science
UR - http://www.scopus.com/inward/record.url?scp=67349212116&partnerID=8YFLogxK
UR - http://www.scopus.com/inward/citedby.url?scp=67349212116&partnerID=8YFLogxK
U2 - 10.1109/TSE.2008.90
DO - 10.1109/TSE.2008.90
M3 - Article
AN - SCOPUS:67349212116
SN - 0098-5589
VL - 35
SP - 293
EP - 304
JO - IEEE Transactions on Software Engineering
JF - IEEE Transactions on Software Engineering
IS - 2 SPEC. ISS.
ER -