Practical initialization race detection for JavaScript web applications

被引:12
作者
Adamsen, Christoffer Quist [1 ,2 ]
Méller, Anders [1 ]
Tip, Frank [2 ]
机构
[1] Aarhus University, Denmark
[2] Northeastern University, United States
基金
欧盟地平线“2020”;
关键词
Model checking - High level languages - Websites - Static analysis;
D O I
10.1145/3133890
中图分类号
学科分类号
摘要
Event races are a common source of subtle errors in JavaScript web applications. Several automated tools for detecting event races have been developed, but experiments show that their accuracy is generally quite low. We present a new approach that focuses on three categories of event race errors that often appear during the initialization phase of web applications: form-input-overwritten errors, late-event-handler-registration errors, and access-before-definition errors. The approach is based on a dynamic analysis that uses a combination of adverse and approximate execution. Among the strengths of the approach are that it does not require browser modifications, expensive model checking, or static analysis. In an evaluation on 100 widely used websites, our tool InitRacer reports 1 085 initialization races, while providing informative explanations of their causes and effects. A manual study of 218 of these reports shows that 111 of them lead to uncaught exceptions and at least 47 indicate errors that affect the functionality of the websites. © 2017 Copyright held by the owner/author(s).
引用
收藏
相关论文
empty
未找到相关数据