Automated Repair of Resource Leaks in Android Applications
Bhargav Nagaraja Bhatt, Carlo A. Furia
TL;DR
PlumbDroid tackles Android resource leaks by marrying a succinct static analysis with a formal automata-theoretic leak model. It builds resource-flow graphs for procedures, uses deterministic pushdown and finite automata to detect leaks via a context-free emptiness check, and automatically generates safe fixes that release leaked resources early in the lifecycle, followed by a validation pass. Empirically, it fixes 50 leaks across 9 resources on 17 apps with high precision and competitive performance, outperforming Relda2/RelFix on non-aliasing resources and producing much smaller patches. The approach shows practical potential for improving Android app quality, while acknowledging aliasing as a key limitation and pointing to future work on alias analysis to broaden applicability.
Abstract
Resource leaks -- a program does not release resources it previously acquired -- are a common kind of bug in Android applications. Even with the help of existing techniques to automatically detect leaks, writing a leak-free program remains tricky. One of the reasons is Android's event-driven programming model, which complicates the understanding of an application's overall control flow. In this paper, we present PlumbDroid: a technique to automatically detect and fix resource leaks in Android applications. PlumbDroid uses static analysis to find execution traces that may leak a resource. The information built for detection also undergirds automatically building a fix -- consisting of release operations performed at appropriate locations -- that removes the leak and does not otherwise affect the application's usage of the resource. An empirical evaluation on resource leaks from the DroidLeaks curated collection demonstrates that PlumbDroid's approach is scalable, precise, and produces correct fixes for a variety of resource leak bugs: PlumbDroid automatically found and repaired 50 leaks that affect 9 widely used resources of the Android system, including all those collected by DroidLeaks for those resources; on average, it took just 2 minutes to detect and repair a leak. PlumbDroid also compares favorably to Relda2/RelFix -- the only other fully automated approach to repair Android resource leaks -- since it usually detects more leaks with higher precision and producing smaller fixes. These results indicate that PlumbDroid can provide valuable support to enhance the quality of Android applications in practice.
