Causality in Configurable Software Systems
This work addresses the challenge of debugging complex configurable software for developers and engineers, though it appears incremental as it extends existing causality concepts to a new domain.
The authors tackled the problem of identifying root causes of defects in configurable software systems by introducing feature causality, a method based on counterfactual reasoning, and demonstrated its feasibility in detecting feature interactions and estimating effects across various benchmarks and real-world systems.
Detecting and understanding reasons for defects and inadvertent behavior in software is challenging due to their increasing complexity. In configurable software systems, the combinatorics that arises from the multitude of features a user might select from adds a further layer of complexity. We introduce the notion of feature causality, which is based on counterfactual reasoning and inspired by the seminal definition of actual causality by Halpern and Pearl. Feature causality operates at the level of system configurations and is capable of identifying features and their interactions that are the reason for emerging functional and non-functional properties. We present various methods to explicate these reasons, in particular well-established notions of responsibility and blame that we extend to the feature-oriented setting. Establishing a close connection of feature causality to prime implicants, we provide algorithms to effectively compute feature causes and causal explications. By means of an evaluation on a wide range of configurable software systems, including community benchmarks and real-world systems, we demonstrate the feasibility of our approach: We illustrate how our notion of causality facilitates to identify root causes, estimate the effects of features, and detect feature interactions.