Back to Search Start Over

Automated Large-Scale Multi-Language Dynamic Program Analysis in the Wild (Tool Insights Paper)

Authors :
Alex Villazón and Haiyang Sun and Andrea Rosà and Eduardo Rosales and Daniele Bonetta and Isabella Defilippis and Sergio Oporto and Walter Binder
Villazón, Alex
Sun, Haiyang
Rosà, Andrea
Rosales, Eduardo
Bonetta, Daniele
Defilippis, Isabella
Oporto, Sergio
Binder, Walter
Alex Villazón and Haiyang Sun and Andrea Rosà and Eduardo Rosales and Daniele Bonetta and Isabella Defilippis and Sergio Oporto and Walter Binder
Villazón, Alex
Sun, Haiyang
Rosà, Andrea
Rosales, Eduardo
Bonetta, Daniele
Defilippis, Isabella
Oporto, Sergio
Binder, Walter
Publication Year :
2019

Abstract

Today’s availability of open-source software is overwhelming, and the number of free, ready-to-use software components in package repositories such as NPM, Maven, or SBT is growing exponentially. In this paper we address two straightforward yet important research questions: would it be possible to develop a tool to automate dynamic program analysis on public open-source software at a large scale? Moreover, and perhaps more importantly, would such a tool be useful? We answer the first question by introducing NAB, a tool to execute large-scale dynamic program analysis of open-source software in the wild. NAB is fully-automatic, language-agnostic, and can scale dynamic program analyses on open-source software up to thousands of projects hosted in code repositories. Using NAB, we analyzed more than 56K Node.js, Java, and Scala projects. Using the data collected by NAB we were able to (1) study the adoption of new language constructs such as JavaScript Promises, (2) collect statistics about bad coding practices in JavaScript, and (3) identify Java and Scala task-parallel workloads suitable for inclusion in a domain-specific benchmark suite. We consider such findings and the collected data an affirmative answer to the second question.

Details

Database :
OAIster
Notes :
application/pdf, English
Publication Type :
Electronic Resource
Accession number :
edsoai.on1358726010
Document Type :
Electronic Resource
Full Text :
https://doi.org/10.4230.LIPIcs.ECOOP.2019.20