Abstract
Many of today’s software systems are parallel or concurrent. With the rise of Node.js and more generally event-loop architectures, many systems need to handle concurrency. However, its nondeterministic behavior makes it hard to reproduce bugs. Today’s interactive debuggers unfortunately do not support developers in debugging non-deterministic issues. They only allow us to explore a single execution path. Therefore, some bugs may never be reproduced in the debugging session, because the right conditions are not triggered. As a solution, we propose multiverse debugging, a new approach for debugging non-deterministic programs that allows developers to observe all possible execution paths of a parallel program and debug it interactively. We introduce the concepts of multiverse breakpoints and stepping, which can halt a program in different execution paths, i.e. universes. We apply multiverse debugging to AmbientTalk, an actor-based language, resulting in Voyager, a multiverse debugger implemented on top of the AmbientTalk operational semantics. We provide a proof of non-interference, i.e., we prove that observing the behavior of a program by the debugger does not affect the behavior of that program and vice versa. Multiverse debugging establishes the foundation for debugging non-deterministic programs interactively, which we believe can aid the development of parallel and concurrent systems.
| Original language | English |
|---|---|
| Publication status | Published - 1 Jul 2019 |
| Event | 33rd European Conference on Object-Oriented Programming - London, London, United Kingdom Duration: 15 Jul 2019 → 19 Jul 2019 https://conf.researchr.org/home/ecoop-2019 https://2019.ecoop.org |
Conference
| Conference | 33rd European Conference on Object-Oriented Programming |
|---|---|
| Abbreviated title | ECOOP 2019 |
| Country/Territory | United Kingdom |
| City | London |
| Period | 15/07/19 → 19/07/19 |
| Internet address |
Fingerprint
Dive into the research topics of 'Multiverse Debugging: Non-deterministic Debugging for Non-deterministic Programs'. Together they form a unique fingerprint.Cite this
- APA
- Author
- BIBTEX
- Harvard
- Standard
- RIS
- Vancouver