Automated Evolution of Feature Logging Statement Levels Using Git Histories and Degree of Interest

04/15/2021
by   Yiming Tang, et al.
0

Logging – used for system events and security breaches to more informational yet essential aspects of software features – is pervasive. Given the high transactionality of today's software, logging effectiveness can be reduced by information overload. Log levels help alleviate this problem by correlating a priority to logs that can be later filtered. As software evolves, however, levels of logs documenting surrounding feature implementations may also require modification as features once deemed important may have decreased in urgency and vice-versa. We present an automated approach that assists developers in evolving levels of such (feature) logs. The approach, based on mining Git histories and manipulating a degree of interest (DOI) model, transforms source code to revitalize feature log levels based on the "interestingness" of the surrounding code. Built upon JGit and Mylyn, the approach is implemented as an Eclipse IDE plug-in and evaluated on 18 Java projects with ∼3 million lines of code and ∼4K log statements. Our tool successfully analyzes 99.26 identifies logs manually modified with a recall of ∼80 level-direction match rate of ∼87 fix contexts ∼83 integrated into large and popular open-source projects. The results indicate that the approach is promising in assisting developers in evolving feature log levels.

READ FULL TEXT

Please sign up or login with your details

Forgot password? Click here to reset