Blog

Answers about Puppet

DevOps, Automation

Universe and Everything

Need Puppet help?

Contact Alessandro Franceschi / example42
for direct expert help on Puppet.
If solution is quick, it’s free. No obligations.

Tip of the Week 48 - Puppet modules documentation

Modules’ documentation is useful to understand what a module does and how it does it and how to make use of it. Usually we can access these information by reading the README, directly on the Forge or GitHub page, and eventually looking directly at the inline documentation in manifests.

Puppet Strings

As you are probably aware there is a tool, Puppet strings which is able to automatically generate documentation for a module based on in code documentation.

It’s based on the Yard tool and can generate docs in various formats.

To install Puppet strings:

puppet resource package rgen provider=puppet_gem
puppet resource package puppet-strings provider=puppet_gem

To generate the documentation for a module, move inside the module main directory and run:

/opt/puppetlabs/puppet/bin/puppet strings generate **/*{.pp\,.rb} **/**/*{.pp\,.rb}

This will parse all the .rb and .pp files in the module and generate html documentation under the doc directory of the module.

Puppet documentation server

Instead of running the puppet strings command on every change in every module, it is also possible to have the strings server checking for changes and rendering documentation upon file changes.

Just change to your control repository, install all modules from Puppetfile by running r10k puppetfile install and run the strings server:

/opt/puppetlabs/puppet/bin/puppet strings server --modulepath=./modules:./site

This will spin up a webservice which is accessible on port 8808: http://localhost:8808

We recommend to not have this web server running on the puppet master. Spin up a new server which will get code updates via git hooks or CI pipelines.

puppetmodule.info

As we know now, Yard can act as a server and show directly the html pages generated. There’s a web site which relies on this and show Puppet strings based documentation for most of the Puppet public modules on the Forge and GitLab.

Give a visit to www.puppetmodule.info, site created by Dominic Cleal from The Foreman team.

Here you can see the documentation for virtually any module you will find yourself using, the site is able to generate on request the documentation for modules it hasn’t yet processed.

So on this site you can look how documented modules appear and search modules and contents as needed.

Control repo documentation

In Psick we use Puppet strings also to generate the documentation of the whole control-repo.

This is Psick’s puppet strings generated documentation (it includes README with merged texts from the psick control-repo and the classes and defines from the psick module). It is automatically generated during the CI pipeline we run on GitLab, relevant lines are here.

As they say: it’s not ready until it’s documented.

How to use puppet strings in your puppet code?

Every class and define must start with the documentation prior class or define definition. Documentation is marked as comments using the hash character (#).

# The demo setup class
#
# This is an example of using documentation in a class or define
#
# @summary this is rendered as summary of the class or define
#
# @example Show how people can make use of the class
#   include demo_setup
#
# @param prod [Boolean] This parameter describes the stage or maturity level
#   of the application. This text is longer, so we use newline for
#   readability
# @param port [Integer] Port on which the demo_setup must run
#
class demo_setup (
  Boolean $prod = true,
  Integer $port = 1025,
){
  # Puppet code
}

Strings can also render documentation from types and providers:

Puppet::Type.newtype(:demo_setup) do
  desc <<-DESC
The type for the demo_setup
@example Show usage for the type
  demo_setup { 'application':
    prod => true,
    port => 8880,
  }
DESC

  newparam(:prod) do
    desc 'Stage to run in'
    # ...
  end
end

Alessandro Franceschi Martin Alfke