Abstract
Past research provided evidence that developers making code changes sometimes omit to update the related documentation, thus creating inconsistencies that may contribute to faults and crashes. In dynamically typed languages, such as Python, an inconsistency in the documentation may lead to a mismatch in type declarations only visible at runtime.
With our study, we investigate how often the documentation is inconsistent in a sample of 239 methods from five Python open- source software projects. Our results highlight that more than 20% of the comments are either partially defined or entirely missing and that almost 1% of the methods in the analyzed projects contain type inconsistencies. Based on these results, we create a tool, PyID, to early detect type mismatches in Python documentation and we evaluate its performance with our oracle.
With our study, we investigate how often the documentation is inconsistent in a sample of 239 methods from five Python open- source software projects. Our results highlight that more than 20% of the comments are either partially defined or entirely missing and that almost 1% of the methods in the analyzed projects contain type inconsistencies. Based on these results, we create a tool, PyID, to early detect type mismatches in Python documentation and we evaluate its performance with our oracle.
Original language | English |
---|---|
Title of host publication | 2018 IEEE Workshop on Machine Learning Techniques for Software Quality Evaluation (MaLTeSQuE) |
Place of Publication | Piscataway, NJ |
Publisher | IEEE |
Pages | 43-48 |
Number of pages | 6 |
ISBN (Electronic) | 978-1-5386-5920-5 |
DOIs | |
Publication status | Published - 2018 |
Event | MaLTeSQuE 2018: 2nd Workshop on Machine Learning Techniques in Software Quality Evaluation - Campobasso, Italy Duration: 20 Mar 2018 → 20 Mar 2018 Conference number: 2 https://maltesque.github.io/ |
Workshop
Workshop | MaLTeSQuE 2018 |
---|---|
Country/Territory | Italy |
City | Campobasso |
Period | 20/03/18 → 20/03/18 |
Other | Collocated with SANER |
Internet address |
Bibliographical note
Accepted Author ManuscriptKeywords
- Documentation
- Python
- Tools
- Runtime
- Computer crashes
- Libraries