Extracting Rationale for Open Source Software Development Decisions -- A Study of Python Email Archives
AI-generated Key Points
- Importance of sound decision-making processes in software project governance, specifically in Open Source Software Development (OSSD) communities
- Lack of exploration into the rationale behind decision-making processes in OSSD communities
- Introduction of Rationale Miner, a heuristics-based rationale extraction system for Python development email archives
- Contribution of knowledge and methodology to the field through large-scale study
- Discussion on limitations of prior works that did not capture rationale behind state transitions in OSSD communities
- Three research questions related to identifying different rationales for decisions, designing an automated approach for extracting rationales, and evaluating effectiveness of this approach
- Revelation of various rationales for Python Enhancement Proposal (PEP) decisions and their prevalence in Python email archives
- Comparison with prior work on Apache decision-making processes and highlighting additional rationales uncovered in this study
- Valuable insights into understanding decision-making processes in OSSD communities and framework for extracting rationales applicable to similar communities.
Authors: Pankajeshwara Nand Sharma, Bastin Tony Roy Savarimuthu, Nigel Stanger
Abstract: A sound Decision-Making (DM) process is key to the successful governance of software projects. In many Open Source Software Development (OSSD) communities, DM processes lie buried amongst vast amounts of publicly available data. Hidden within this data lie the rationale for decisions that led to the evolution and maintenance of software products. While there have been some efforts to extract DM processes from publicly available data, the rationale behind how the decisions are made have seldom been explored. Extracting the rationale for these decisions can facilitate transparency (by making them known), and also promote accountability on the part of decision-makers. This work bridges this gap by means of a large-scale study that unearths the rationale behind decisions from Python development email archives comprising about 1.5 million emails. This paper makes two main contributions. First, it makes a knowledge contribution by unearthing and presenting the rationale behind decisions made. Second, it makes a methodological contribution by presenting a heuristics-based rationale extraction system called Rationale Miner that employs multiple heuristics, and follows a data-driven, bottom-up approach to infer the rationale behind specific decisions (e.g., whether a new module is implemented based on core developer consensus or benevolent dictator's pronouncement). Our approach can be applied to extract rationale in other OSSD communities that have similar governance structures.
Ask questions about this paper to our AI assistant
You can also chat with multiple papers at once here.
Assess the quality of the AI-generated content by voting
Score: 0
Why do we need votes?
Votes are used to determine whether we need to re-run our summarizing tools. If the count reaches -10, our tools can be restarted.
The previous summary was created more than a year ago and can be re-run (if necessary) by clicking on the Run button below.
Similar papers summarized with our AI tools
Navigate through even more similar papers through a
tree representationLook for similar papers (in beta version)
By clicking on the button above, our algorithm will scan all papers in our database to find the closest based on the contents of the full papers and not just on metadata. Please note that it only works for papers that we have generated summaries for and you can rerun it from time to time to get a more accurate result while our database grows.
Disclaimer: The AI-based summarization tool and virtual assistant provided on this website may not always provide accurate and complete summaries or responses. We encourage you to carefully review and evaluate the generated content to ensure its quality and relevance to your needs.