Abstract

Background: Bug tracking systems receive many bug reports daily. Although the software quality team aims to identify and resolve these bugs, they are never able to fix all of the reported bugs in the issue tracking system before the release deadline. However, postponing the bug fixing may have some consequences. Prioritization of bug reports will help the software manager decide which bugs to fix and which bugs to postpone. Typically, bug reports are prioritized based on the severity, priority, time and effort for fixing, customer pressure, etc. Aim: Previous studies have shown that these factors may not be appropriate for prioritization. Therefore, relying on them to automate bug prioritization might be misleading. In this dissertation, we aim to prioritize bug reports with respect to the consequence of not fixing the bugs in terms of their relative importance in the issue tracking system. Method: In order to measure the relative importance of bugs in the issue tracking system, we propose the construction of a dependency graph based on the reported dependency-blocking information in the issue tracking system. Two metrics, namely depth and degree, are used to measure the relative importance of the bugs. However, there is uncertainty in the dependency graph structure as the dependency information is discovered manually and gradually. Owing to this uncertainty, prioritization of bugs in the descending order of depth and degree may be misleading. To handle the uncertainty, we propose a novel approach of a partially observable Markov decision process (POMDP) and partially observable Monte Carlo planning (POMCP). Result: To check the feasibility of the proposed approach, we analyzed seven years of data from an open source project, Firefox, and a commercial project. We compared the proposed policy with the developer policy, maximum policy, and random policy. Conclusion: The results suggest that software practitioners do not consider the relative importance of bugs in their current practice. The proposed framework can be combined with practitioners’ expertise to prioritize bugs more effectively and take the depth and degree of bugs into account. In practice, the POMDP framework with the POMCP planner can help practitioners sequentially select bugs to minimize the connectivity of the dependency graph.

Highlights

  • 1.1 IntroductionSoftware maintenance is a dominant factor affecting the cost of large software systems [35]

  • The results suggest that software practitioners do not consider the relative importance of bugs in their current practice

  • The partially observable Markov decision process (POMDP) framework with the partially observable Monte Carlo planning (POMCP) planner can help practitioners sequentially select bugs to minimize the connectivity of the dependency graph

Read more

Summary

Introduction

1.1 IntroductionSoftware maintenance is a dominant factor affecting the cost of large software systems [35]. To approve the valid change requests, some factors are considered, including but not limited to the consequence of avoiding changes, the cost and benefit of the change, the number of affected users, and the release deadline [144]. In Bugzilla, there are some fields for the location of the bug and the time the bug is reported in the bug tracking system. It includes the product, component, status, creation time (reported), and last modified time (modified). “Reporter” is a user or a developer who reports the problem in the bug tracking system. The software quality team aims to identify and resolve these bugs, they are never able to fix all of the reported bugs in the issue tracking system before the release deadline. Bug reports are prioritized based on the severity, priority, time and effort for fixing, customer pressure, etc

Objectives
Methods
Results
Conclusion

Talk to us

Join us for a 30 min session where you can share your feedback and ask us any queries you have

Schedule a call

Disclaimer: All third-party content on this website/platform is and will remain the property of their respective owners and is provided on "as is" basis without any warranties, express or implied. Use of third-party content does not indicate any affiliation, sponsorship with or endorsement by them. Any references to third-party content is to identify the corresponding services and shall be considered fair use under The CopyrightLaw.