µPuppet: A Declarative Subset of the Puppet Configuration Language∗ Weili Fu1, Roly Perera2, Paul Anderson3, and James Cheney4 1 School of Informatics, University of Edinburgh, Edinburgh, UK
[email protected] 2 School of Informatics, University of Edinburgh, Edinburgh, UK
[email protected] School of Computing Science, University of Glasgow, Glasgow, UK
[email protected] 3 School of Informatics, University of Edinburgh, Edinburgh, UK
[email protected] 4 School of Informatics, University of Edinburgh, Edinburgh, UK
[email protected] Abstract Puppet is a popular declarative framework for specifying and managing complex system con- figurations. The Puppet framework includes a domain-specific language with several advanced features inspired by object-oriented programming, including user-defined resource types, ‘classes’ with a form of inheritance, and dependency management. Like most real-world languages, the language has evolved in an ad hoc fashion, resulting in a design with numerous features, some of which are complex, hard to understand, and difficult to use correctly. We present an operational semantics for µPuppet, a representative subset of the Puppet language that covers the distinctive features of Puppet, while excluding features that are either deprecated or work-in-progress. Formalising the semantics sheds light on difficult parts of the language, identifies opportunities for future improvements, and provides a foundation for future analysis or debugging techniques, such as static typechecking or provenance tracking. Our se- mantics leads straightforwardly to a reference implementation in Haskell. We also discuss some of Puppet’s idiosyncrasies, particularly its handling of classes and scope, and present an initial corpus of test cases supported by our formal semantics.