On Monday, February 2, 2015 at 12:21:40 PM UTC-6, Lauren R wrote: > > The Modules team and I are excited to finally announce the newest version > of the Puppet Language Style Guide. > > We've reworked the guide to reflect the new features and capabilities of > Puppet 3.7, and we've expanded it to cover more topics related to building > manifests and modules. If you're interested in publishing a module to the > Puppet Forge or are looking to get your module "Puppet Approved," the > updated guide is a great place to start. > > It was a massive, company-wide effort to update this style guide, but I'm > sure we didn't catch everything. If you notice a mistake or would like more > information on something that's not currently covered, please file a > ticket. We plan to regularly update the guide from here on out, and we > definitely anticipate another big release in the months after Puppet 4 > comes out. >
I'm pleased to see PL directing time and attention to such an effort, and I congratulate you on bringing it to this milestone. With that said, I'm afraid I have a quite a few criticisms of the current version of the document. I hope you will find them constructive in nature: *Overall document issues* The very first thing that hit me when I sat down to read the guide was section 1, with its reference to RFC 2119 terminology. What in the world is such a thing doing in a **style** **guide**? That describes the terminology of a specification document. If a specification is what you mean this to be, then kindly position it that way. In fact, the terminology matter is symptomatic of a deeper issue: the document appears to be at least two different documents mashed together. At times it wants to be a DSL style guide / specification, but at other times it wants to be a module layout specification (not much "guiding" on that side). There is some overlap between those areas, to be sure, but it would be better to have two documents, each more tightly focused. Some of my per-section comments will also reflect on this issue. *Specific issues with guidelines* Section 4: versioning is not a style issue. Section 5: how is trailing whitespace a style issue of any consequence? It has no *bona fide* relationship to the guiding principles enumerated in section 3 of the document. It's not that I'm a big fan of trailing whitespace, but this seems so superfluous. The only practical reason I see to include it (as a "must", no less) is to simplify the implementation of style checkers. Not welcome. Section 7: as a matter of style, why *shouldn't* comments explain the "how" of the code? In the event that it is unclear how the code accomplishes the "why", documentation of that "how" is important for maintaining the code. I suspect that there are particular practices that this guideline is trying to rule out, but if so then a more nuanced guideline is needed. Additionally, I don't like *either* of the examples. For what it's worth, the comment, if any, with which *I* would adorn the example declaration would be something like "Manages the main NTP configuration file". (And I note that I would characterize that more as a "what" than as either a "why" or a "how".) Section 8. Having module metadata is not a style issue. I thought perhaps this point was about the style to be used for a module metadata file, which might be ok, but if that was the intention then the actual section is a complete miss. Moreover, it is not clear either in the style guide or in the document it references what the metadata "format" actually is, unless the answer is simply "JSON". Perhaps "format" is the wrong word for what you're trying to describe. Section 10.2, item 7: in addition to comments in previous posts regarding this declaration-ordering recommendation, I observe that it conflicts with guideline 9.4 about putting declarations in logical groupings. Section 10.2: the justification for the recommendation that "the last two items – declared resources and declared relationships to other classes/defines – not occur in the same class or type" is unclear. I'm inclined to call such a recommendation altogether *un*justified, but perhaps I don't understand what the guide is trying to say. Section 10.7: the specified style for parameter defaults is fine for classes, but it is not applicable to defined types. I don't know how to safely satisfy the guide's recommendation that "Provided defaults should be specified with the parameter and not inside the [...] define." Section 11.2: WHAT? In the first place, what "non-deterministic scoping issues" are we talking about here? In the second place, how are classes *supposed* to declare other classes? The only other alternative -- resource-style class declarations -- are inferior in most situations, as even the language reference acknowledges: "*Most* users in *most* situations should use include-like declarations" (emphasis in the original). Is this issue even really about class declaration style at all? If not, then why does it call out the "include" function? Section 12.1: This is worded confusingly. I guess it's trying to say that declarations of resources of a defined type should specify a resource title that includes a characteristic variable's value, so as to ensure that multiple instances' titles do not collide. Although the text is unclear, I take issue even more with the guideline itself. It is a design / implementation consideration, not a style issue, and more importantly, it is not valid as a general rule. There absolutely are cases where I want to declare a defined type instance with a static title, just like there are cases where I want to declare an instance of a plugin type with a static title. There is nothing inherently wrong with that. Sections 16 & 17: These are not points of style, they are points of module organization / documentation / layout. They do not belong in a style guide. Section 18: What does this have to do with style? Or even with module design / layout / etc.? I don't object to it is a good general rule, but it does not belong in a style guide, and maybe not even in the other document(s) that is currently trying to live inside the same text. Section 19: if the guide is intended to serve as a design document for the *-lint programs, then that would be better described in section 2 ("Purpose"), in those terms. If it really just "helps" development of those tools, then there is no reason to mention that in the guide itself at all. If the point is supposed to be that those programs can help *check* compliance with the style guide then I think that's out of place inside the guide itself. If in that case you insist on referencing the *-lints anyway, then you should put them in that context (i.e. compliance-management tools). *Issues with guide text* Section 3, item 2: the text of this item is nearly a complete miss for me. The text doesn't really describe what it means by "simplicity", and it seems not to touch on "scoping" at all. Even though I think I know what you're talking about, the text is pretty unclear with respect to the odd significance it attributes to the word "and". Moreover, although some aspects of "scope" and "simplicity" might well be considered matters of style, what you seem actually to be talking about is not that at all; rather, it is a module design principle. Section 6: the guide is inconsistent and incomplete with respect to quoting. It says "all strings must be enclosed in single quotes" with certain exceptions, but it does not say what should be done in the exceptional cases (they should be enclosed in double quotes, presumably). And then the very next item says certain other strings don't need to be quoted, in contradiction of the previous point. The apparent intention there is just fine, but the text could use some work. Section 10.1 seems to preclude manifests residing in subdirectories of a module's 'manifests' directory, as in fact is a relatively common practice. I'm accounting this a text issue because I don't think it is actually the intention to exclude such arrangements (where they in fact correspond correctly to class / define names). Section 10.5: it's unclear what "close to node scope" means in this context, if it in fact adds anything at all to what is already stated in the preceding sentence. Section 10.5: The sentence "If you have a class or define which requires another class or define, graceful failures must be in place if those required classes or defines are not declared elsewhere" seems not to apply to the situations described in the examples. This revolves around the meaning of the word "declare" (which perhaps should be defined in the document): both the examples revolve around (nested) *definitions* -- one of a class, the other of a defined type -- not around declarations. Section 10.8: This whole section seems kind of murky to me. I think it must be inspired by some specific cases, and perhaps I would understand if I were familiar with those cases. As it is, though, the attempt at generalization is not working for me. I understand the words, but I'm genuinely having trouble understanding the big picture of what the section is really driving at. Section 11.1: Tucked at the end of this section is "Remember: Class inheritance should only be used for myclass::params parameter defaults." That's a lot more specific than the rather large volume of text and examples preceding it. If it's really what the section is trying to say then you should make it the guideline and lead off with it; otherwise you should omit it. ---- That's it for now. John -- You received this message because you are subscribed to the Google Groups "Puppet Users" group. To unsubscribe from this group and stop receiving emails from it, send an email to puppet-users+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/puppet-users/011324f7-4983-4baf-891d-e8b8a72f7a8c%40googlegroups.com. For more options, visit https://groups.google.com/d/optout.