“Don’t Call Us, We’ll Call You: Characterizing Callbacks in JavaScript”, Keheliya Gallaba, Ali Mesbah, and Ivan Beschastnikh.
In Proceedings of the ACM/IEEE International Symposium on Empirical Software Engineering and Measurement (ESEM), 247–256, 2015
[Best Full Paper Award]
[PDF

Abstract

JavaScript is a popular language for developing web applications and is increasingly used for both client-side and server-side application logic. The JavaScript runtime is inherently event-driven and callbacks are a key language feature. Unfortunately, callbacks induce a non-linear control flow and can be deferred to execute asynchronously, declared anonymously, and may be nested to arbitrary levels. All of these features make callbacks difficult to understand and maintain. We perform an empirical study to characterize JavaScript callback usage across a representative corpus of 138 JavaScript programs, with over 5 million lines of JavaScript code. We find that on average, every 10th function definition takes a callback argument, and that over 43% of all callback-accepting function callsites are anonymous. Furthermore, the majority of callbacks are nested, more than half of all callbacks are asynchronous, and asynchronous callbacks, on average, appear more frequently in client-side code (72%) than server-side (55%). We also study three well-known solutions designed to help with the complexities associated with callbacks, including the error-first callback convention, Async.js library, and Promises. Our results inform the design of future JavaScript analysis and code comprehension tools.

BibTeX

@inproceedings{esem15,
  author = {Gallaba, Keheliya and Mesbah, Ali and Beschastnikh, Ivan},
  title = {Don't Call Us, We'll Call You: Characterizing Callbacks in {JavaScript}},
  booktitle = {Proceedings of the ACM/IEEE International Symposium on Empirical Software Engineering and Measurement (ESEM)},
  publisher = {IEEE Computer Society},
  pages = {247--256},
  year = {2015},
  url = {http://salt.ece.ubc.ca/callback-study/esem15-js-callbacks-study.pdf},
  award = {[Best Full Paper Award]}
}