How Users Interpret Bugs in Trigger-Action Programming.

Will Brackenbury,Abhimanyu Deora,Jillian Ritchey,Jason Vallee,Weijia He,Guan Wang,Michael L. Littman,Blase Ur
DOI: https://doi.org/10.1145/3290605.3300782
2019-01-01
Abstract:Trigger-action programming (TAP) is a programming model enabling users to connect services and devices by writing if-then rules. As such systems are deployed in increasingly complex scenarios, users must be able to identify programming bugs and reason about how to fix them. We first systematize the temporal paradigms through which TAP systems could express rules. We then identify ten classes of TAP programming bugs related to control flow, timing, and inaccurate user expectations. We report on a 153-participant online study where participants were assigned to a temporal paradigm and shown a series of pre-written TAP rules. Half of the rules exhibited bugs from our ten bug classes. For most of the bug classes, we found that the presence of a bug made it harder for participants to correctly predict the behavior of the rule. Our findings suggest directions for better supporting end-user programmers.
What problem does this paper attempt to address?