MuAkka: Mutation Testing for Actor Concurrency in Akka Using Real-World Bugs
Actor concurrency is becoming increasingly important in the real-world and mission-critical software. This requires these applications to be free from actor bugs, that occur in the real world, and have tests that are effective in finding these bugs. Mutation testing is a well-established technique that transforms an application to induce its likely bugs and evaluate the effectiveness of its tests in finding these bugs. Mutation testing is available for a broad spectrum of applications and their bugs, ranging from web to mobile to machine learning, and is used at scale in companies like Google and Facebook. However, there still is no mutation testing for actor concurrency that uses real-world actor bugs. In this paper, we propose 𝜇Akka, a framework for mutation testing of Akka actor concurrency using real actor bugs. Akka is a popular industrial-strength implementation of actor concurrency. To design, implement, and evaluate 𝜇Akka, we take the following major steps. (1) manually analyze a recent set of 186 real Akka bugs from Stack Overflow and GitHub to understand their causes. (2) design a set of 32 mutation operators, with 138 source code changes in Akka API, to emulate these causes and induce their bugs. (3) implement these operators in an Eclipse plugin for Java Akka. (4) use the plugin to generate 11.7K mutants of 10 real GitHub applications, with 446.4k lines of code and 7.9k tests. (5) run these tests on these mutants to measure the quality of mutants and effectiveness of tests. (6) use PIT to generate 26.2k mutants to compare 𝜇Akka and PIT mutant quality and test effectiveness. PIT is a popular mutation testing tool with traditional operators. (7) manually analyze the bug coverage and overlap of 𝜇Akka, PIT, and actor operators in a previous work. (8) discuss a few implications of our findings. Among others, we find that 𝜇Akka mutants are higher quality, cover more bugs, and tests are less effective in detecting them.