Publication | Closed Access
An Empirical Study of Type-Related Defects in Python Projects
18
Citations
26
References
2021
Year
Software MaintenanceEngineeringProject ManagementSoftware EngineeringSoftware AnalysisType CheckerEmpirical Software Engineering ResearchStatic Type CheckerData ScienceDependently Typed ProgrammingProgramming LanguagesDesignComputer ScienceType SystemAutomated RepairSoftware DesignProgram AnalysisSoftware TestingFormal MethodsMathematical FoundationsPython ProjectsType Annotations
In recent years, <monospace xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">Python</monospace> has experienced an explosive growth in adoption, particularly among open source projects. While <monospace xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">Python</monospace> 's dynamically-typed nature provides developers with powerful programming abstractions, that same dynamic type system allows for type-related defects to accumulate in code bases. To aid in the early detection of type-related defects, type annotations were introduced into the <monospace xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">Python</monospace> ecosystem (i.e., PEP-484) and static type checkers like <monospace xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">mypy</monospace> have appeared on the market. While applying a type checker like <monospace xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">mypy</monospace> can in theory help to catch type-related defects before they impact users, little is known about the real impact of adopting a type checker to reveal defects in <monospace xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">Python</monospace> projects. In this paper, we study the extent to which <monospace xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">Python</monospace> projects benefit from such type checking features. For this purpose, we mine the issue tracking and version control repositories of 210 <monospace xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">Python</monospace> projects on GitHub. Inspired by the work of Gao <italic xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">et al.</i> on type-related defects in JavaScript, we add type annotations to test whether <monospace xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">mypy</monospace> detects an error that would have helped developers to avoid real defects. We observe that 15 percent of the defects could have been prevented by <monospace xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">mypy</monospace> . Moreover, we find that there is no significant difference between the experience level of developers committing type-related defects and the experience of developers committing defects that are not type-related. In addition, a manual analysis of the anti-patterns that most commonly lead to type-checking faults reveals that the redefinition of <monospace xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">Python</monospace> references, dynamic attribute initialization and incorrectly handled Null objects are the most common causes of type-related faults. Since our study is conducted on fixed public defects that have gone through code reviews and multiple test cycles, these results represent a lower bound on the benefits of adopting a type checker. Therefore, we recommend incorporating a static type checker like <monospace xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">mypy</monospace> into the development workflow, as not only will it prevent type-related defects but also mitigate certain anti-patterns during development.
| Year | Citations | |
|---|---|---|
Page 1
Page 1