(PDOC-133) Edits to Strings README

This commit is contained in:
jbondpdx 2016-11-23 10:49:09 -08:00
parent 95df5e6fa9
commit 1f9a99a37a
1 changed files with 201 additions and 147 deletions

348
README.md
View File

@ -6,8 +6,6 @@ A Puppet command built on [YARD](http://yardoc.org/).
Puppet Strings generates HTML documentation for Puppet extensions written in Puppet and Ruby.
This tool will eventually place the existing `puppet doc` command once feature parity has been achieved.
| | |
| -------------- |---------------------------------------------------------------- |
| *Code* | [GitHub][repo] |
@ -23,123 +21,155 @@ This tool will eventually place the existing `puppet doc` command once feature p
[contributing]: https://github.com/puppetlabs/puppet-strings/blob/master/CONTRIBUTING.md
[committers]: https://github.com/puppetlabs/puppet-strings/blob/master/COMMITTERS.md
Requirements
------------
## Installing Puppet Strings
In order to run strings you need to have the following software installed:
### Requirements
To run Strings, you need the following software:
* Ruby 1.9.3 or newer
* Puppet 3.7 or newer
* The `yard` Ruby gem
Note that a few extra steps are necessary to install puppet-strings with Puppet Enterprise 3.8.
Note that if you are running PE 3.8, you'll have a few extra steps to install puppet-strings.
Installing the YARD Gem
-----------------------
### 1. Install the YARD Gem
The easiest way to install the `yard` gem is with Puppet itself:
For Puppet 4.x and Puppet Enterprise 2015.2 and later:
```
$ puppet resource package yard provider=puppet_gem
```
For Puppet 3.x:
```
$ puppet resource package yard provider=gem
```
For Puppet Enterprise 3.8:
```
GEM_HOME=/opt/puppet/lib/ruby/gems/1.9.1 puppet resource package yard provider=gem
```
Installing the redcarpet Gem (Puppet Enterprise 3.8 only)
-------------------------
### 2. Puppet Enterprise 3.8 only: Install the redcarpet gem
```
GEM_HOME=/opt/puppet/lib/ruby/gems/1.9.1 puppet resource package redcarpet provider=gem
```
Installing Puppet Strings
-------------------------
### 3. Install Puppet Strings
Strings can be installed using the [puppet-strings](https://rubygems.org/gems/puppet-strings) gem.
To ensure it is installed in right place, it is best to install it using Puppet:
Install the [puppet-strings](https://rubygems.org/gems/puppet-strings) gem. To ensure that Strings is installed in the right place, install the gem with Puppet as shown below.
For Puppet 4.x and Puppet Enterprise 2015.2 and later:
```
$ puppet resource package puppet-strings provider=puppet_gem
```
For Puppet 3.x:
```
$ puppet resource package puppet-strings provider=gem
```
For Puppet Enterprise 3.8:
```
GEM_HOME=/opt/puppet/lib/ruby/gems/1.9.1 puppet resource package puppet-strings provider=gem
```
Running Puppet Strings
----------------------
### 4. Optional: Set YARD options for Strings
Once strings has been installed you can document a puppet module:
Puppet Strings supports YARD options (on the command line, run `yard help doc` for a list of possible options. To set YARD options, specify a `yardopts` file in the same directory in which you run `puppet strings`.
Puppet Strings supports the Markdown format and automatically sets the YARD `markup` option to `markdown`.
## Generating documentation with Puppet Strings
The `puppet strings` command processes the `README` file, as well as all Puppet and Ruby source files under the `./manifests/`, `./functions/`, and `./lib/`
directories, and then creates HTML documentation under the `./doc/` directory.
### Generate module documentation
To generate documentation for a Puppet module, run Strings from that module's directory.
1. Change directory into the module: `cd /modules/sample-module`.
2. Run the command: `puppet strings`.
### Generate documentation for specific files
To generate documentation for specific files in a module, run the `puppet strings generate` subcommand and specify the files.
```
$ cd /path/to/module
$ puppet strings
puppet strings generate first.pp second.pp`
```
This processes `README` and all Puppet and Ruby source files under the `./manifests/`, `./functions/`, and `./lib/`
directories by default and creates HTML documentation under the `./doc/` directory.
To document specific files:
```
$ puppet strings generate first.pp second.pp ...
```
To document specific directories:
To generate documentation for specific directories, run the `puppet strings generate` command and specify the directories:
```
$ puppet strings generate 'modules/foo/lib/**/*.rb' 'modules/foo/manifests/**/*.pp' 'modules/foo/functions/**/*.pp' ...
```
Strings can emit JSON documenting the Puppet extensions:
### Set additional options for document generation
```
$ puppet strings generate --emit-json documentation.json
```
If you need to specify additional options when generating documentation, use the `puppet strings:generate` rake task. This command behaves exactly as `puppet strings generate`, but allows you to add the following parameters:
It can also print the JSON to stdout:
* `patterns`: the search patterns to use for finding files to document (defaults to `manifests/**/*.pp functions/**/*.pp types/**/*.pp lib/**/*.rb`).
* `debug`: enables debug output when set to `true`.
* `backtrace`: enables backtraces for errors when set to `true`.
* `markup`: the markup language to use (defaults to `markdown`).
* `yard_args`: additional arguments to pass to YARD.
```
$ puppet strings generate --emit-json-stdout
```
For setup and usage details for the `puppet strings:generate` task, see [Rake tasks](#rake-tasks).
The schema for the JSON output is [documented here](https://github.com/puppetlabs/puppet-strings/blob/master/JSON.md).
## Viewing generated documentation
In addition to generating a directory full of HTML, you can also serve up documentation for all your modules using the `server` action:
Strings generates documentation as HTML in a `./doc/` directory within the module for which you are generating documentation. Strings can also serve the generated docs locally or output documentation in JSON.
### Serve documents locally
Strings can serve the generated HTML documentation with the `server` action. This action serves documentation for all modules in the [module path](https://docs.puppet.com/puppet/latest/reference/dirs_modulepath.html) at `http://localhost:8808`.
To serve documentation locally, run:
```
$ puppet strings server
```
YARD Options
------------
### Output documents in JSON
YARD options (see `yard help doc`) are supported in a `.yardopts` file in the same directory where `puppet strings` is run.
Strings can produce documentation in JSON and then either generate a `.json` file or print JSON to stdout. This can be useful for handling or displaying the data with your own custom applications.
Puppet Strings automatically sets the `markup` option to `markdown`, allowing your documentation strings to be in Markdown format.
To generate JSON documentation to a file, run:
Documenting Puppet Extensions
-----------------------------
```
$ puppet strings generate --emit-json documentation.json
```
### Puppet Classes / Defined Types
To generate and then print JSON documentation to stdout, run:
To document Puppet classes and defined types, use a YARD docstring before the class or defined type definition:
```
$ puppet strings generate --emit-json-stdout
```
For details about Strings JSON output, see [Strings JSON schema](https://github.com/puppetlabs/puppet-strings/blob/master/JSON.md).
### Output documents to GitHub Pages
To generate documents and then make them available on [GitHub Pages](https://pages.github.com/), use the Strings rake task `strings:gh_pages:update`. See [Rake tasks](#rake-tasks) for setup and usage details.
## Documenting Puppet code for Strings
Strings relies on code comments and YARD docstrings to specify documentation comments. Comments can include free-form text that is treated as a high-level overview for the element being documented. You can also include any number of YARD tags that hold semantic metadata for various aspects of the code. These tags allow you to add this data to the code without worrying about presentation.
### Documenting Puppet classes and defined types
To document Puppet classes and defined types, use a series of comments to create a YARD docstring before the class or defined type definition.
```puppet
# An example class.
@ -157,8 +187,27 @@ class example_class(
) inherits example::params {
# ...
}
```
# An example defined type.
The Strings elements appearing in the above comment block are:
* Three comment lines, not prefixed with tags, give the class description.
* The `@example` YARD tag, immediately followed by an optional title.
* The `include` statement, which adds the usage example code.
* Two `@param` tags, with the name of the parameter first, followed by a string describing the parameter's purpose.
Puppet 4 is a typed language, so Puppet Strings automatically documents the parameter types from code. With Puppet 3, however, include the parameter type with the `@param` tag:
```
# @param [String] first The first parameter for this class.
# @param [Integer] second The second parameter for this class.
```
Note that if you document a parameter's type, and that parameter already has a Puppet type specifier, Strings emits a warning.
Defined types are documented in exactly the same way as classes:
```
#
# This is an example of how to document a defined type.
# @param ports The array of port numbers to use.
@ -169,12 +218,9 @@ define example_type(
}
```
***Note: unlike Ruby, Puppet 4.x is a typed language; Puppet Strings will automatically use the parameter type information to
document the parameter types. A warning will be emitted if you document a parameter's type for a parameter that has a Puppet type specifier.***
### Documenting resource types and providers
### Resource Types
To document custom resource types and their parameters/properties, use the `desc` method or assign a value to the `doc` attribute:
To document resource types, pass descriptions for each parameter, property, and the resource type itself to the `desc` method. Each description can include other tags as well, including examples.
```ruby
Puppet::Type.newtype(:example) do
@ -199,13 +245,8 @@ DESC
# ...
end
```
Puppet Strings documents this way to preserve backwards compatibility with `puppet doc` and existing resource types.
***Note: Puppet Strings does not evaluate your Ruby code, so only certain static expressions are supported.***
To document parameters and properties that are dynamically created, use the `#@!puppet.type.param` and `#@!puppet.type.property`
directives before the `newtype` call:
If your resource type includes dynamically created parameters and properties, you must also use the `#@!puppet.type.param` and `#@!puppet.type.property` directives **before** the `newtype` call. This is necessary because Strings does not evaluate Ruby code, so it cannot detect dynamic attributes.
```ruby
# @!puppet.type.param [value1, value2, value3] my_param Documentation for a dynamic parameter.
@ -215,9 +256,7 @@ Puppet::Type.newtype(:example) do
end
```
### Providers
To document providers, use the `desc` method or assign a value to the `doc` attribute:
Document providers similarly, again using the `desc` method:
```ruby
Puppet::Type.type(:example).provide :platform do
@ -227,39 +266,17 @@ Puppet::Type.type(:example).provide :platform do
end
```
Puppet Strings documents this way to preserve backwards compatibility with `puppet doc` and existing resource types.
All provider method calls, including `confine`, `defaultfor`, and `commands`, are automatically parsed and documented by Strings. The `desc` method is used to generate the docstring, and can include tags such as `@example` if written as a heredoc.
***Note: Puppet Strings does not evaluate your Ruby code, so only certain static expressions are supported.***
**Note**: Puppet Strings can not evaluate your Ruby code, so only certain static expressions are supported.
### Functions
### Documenting functions
Puppet Strings supports three different ways of defining a function in Puppet: with the Puppet 3.x API, Puppet 4.X API,
and in the Puppet language itself.
Puppet Strings supports the documenting of defined functions with the Puppet 4 API, the Puppet 3 API, or in the Puppet language itself.
#### Puppet 3.x Functions
#### Document Puppet 4 functions
To document a function in the Puppet 3.x API, use the `doc` option to `newfunction`:
```ruby
Puppet::Parser::Functions.newfunction(:example, doc: <<-DOC
Documentation for an example 3.x function.
@param [String] param1 The first parameter.
@param [Integer] param2 The second parameter.
@return [Undef]
@example Calling the function.
example('hi', 10)
DOC
) do |*args|
#...
end
```
***Note: if parameter types are omitted, a default of the `Any` Puppet type will be used.***
#### Puppet 4.x Functions
To document a function in the Puppet 4.x API, use a YARD docstring before the `create_function` call and any `dispatch`
calls:
To document a function in the Puppet 4 API, use a YARD docstring before the `create_function` call and before any `dispatch` calls:
```ruby
# An example 4.x function.
@ -278,11 +295,9 @@ Puppet::Functions.create_function(:example) do
end
```
***Note: Puppet Strings will automatically use the parameter type information from the `dispatch` block to document
the parameter types. Only document your parameter types when the Puppet 4.x function contains no `dispatch` calls.***
**Note**: Puppet Strings automatically uses the parameter type information from the `dispatch` block to document the parameter types. Only document your parameter types when the Puppet 4.x function contains no `dispatch` calls.
If the Puppet 4.x function contains multiple `dispatch` calls, Puppet Strings will automatically create `overload` tags
to describe the function's overloads:
If the Puppet 4 function contains multiple `dispatch` calls, Puppet Strings automatically creates `overload` tags to describe the function's overloads:
```ruby
# An example 4.x function.
@ -308,9 +323,29 @@ Puppet::Functions.create_function(:example) do
# ...
```
The resulting HTML for this example function will document both `example(String $first)` and `example(Integer $first)`.
The resulting HTML for this example function documents both `example(String $first)` and `example(Integer $first)`.
#### Puppet Language Functions
#### Document Puppet 3 functions
To document a function in the Puppet 3 API, use the `doc` option to `newfunction`:
```ruby
Puppet::Parser::Functions.newfunction(:example, doc: <<-DOC
Documentation for an example 3.x function.
@param [String] param1 The first parameter.
@param [Integer] param2 The second parameter.
@return [Undef]
@example Calling the function.
example('hi', 10)
DOC
) do |*args|
#...
end
```
Because Puppet 3 is not typed in the way Puppet 4 is, specify the type for each parameter (for example, `@param [String]` for a string parameter). If a parameter type is omitted, a default of the `Any` Puppet type will be used.
#### Document Puppet language functions
To document Puppet functions written in the Puppet language, use a YARD docstring before the function definition:
@ -325,15 +360,11 @@ function example(String $name) {
}
```
***Note: Puppet Strings will automatically use the parameter type information from the function's parameter list to document
the parameter types.***
**Note**: Puppet Strings automatically uses the parameter type information from the function's parameter list to document the parameter types.
Further examples
----------------
### Including examples in documentation
#### Using The `@example` Tag
The `@example` YARD tag can be used to add usage examples to any Ruby or Puppet language code.
The `@example` YARD tag adds usage examples to any Ruby or Puppet language code.
```puppet
# @example String describing what this example demonstrates.
@ -351,13 +382,14 @@ The string following the `@example` tag is an optional title which is displayed
The example body must begin on a newline underneath the tag, and each line of the example itself must be indented by
at least one space. Further indentation is preserved as preformatted text in the generated documentation.
#### Multi-Line Tag Descriptions
### Including multi-line tag descriptions
Similar to multi-line examples, tag descriptions can be spread across multiple lines as long as subsequent lines
are each uniformly indented by at least one space.
You can spread tag descriptions across multiple lines, similar to multi-line examples, as long as subsequent lines are each uniformly indented by at least one space.
For example:
```puppet
# @param name The name which the function will use to say hello. Note that this
# @param name The name the function uses to say hello. Note that this
# description is extra long, so we've broken it up onto newlines for the sake
# of readability.
function example(string $name) {
@ -365,39 +397,53 @@ function example(string $name) {
}
```
Additional Resources
--------------------
## Reference
Here are a few other good resources for getting started with documentation:
### Available Strings tags
* [Module README Template](https://docs.puppet.com/puppet/latest/reference/modules_documentation.html)
* [YARD Getting Started Guide](http://www.rubydoc.info/gems/yard/file/docs/GettingStarted.md)
* [YARD Tags Overview](http://www.rubydoc.info/gems/yard/file/docs/Tags.md)
The most commonly used tags for Strings are:
Rake Tasks
----------
* `@param`: Documents a parameter with a given name, type and optional description.
* `@return`: Describes the return value (and type or types) of a method. You can list multiple return tags for a method if the method has distinct return cases. In this case, begin each case with "if".
* `@example`: Shows an example snippet of code for an object. The first line is an optional title. See above for more about how to [include examples in documentation](#including-examples-in-documentation).
* `@!puppet.type.param`: Documents dynamic type parameters. See [Documenting resource types and providers](#documenting-resource-types-and-providers) above.
* `@!puppet.type.property`: Documents dynamic type properties. See [Documenting resource types and providers](#documenting-resource-types-and-providers) above.
* `@since`: Lists the version in which the object was first added.
* `@see`: Adds "see also" references. Accepts URLs or other code objects with an optional description at the end. Note that the URL or object is automatically linked by YARD and does not need markup formatting.
Puppet Strings comes with two rake tasks: `strings:generate` and `strings:gh_pages:update` available in `puppet-strings/tasks`.
For a complete list of tags, see the [YARD Tags Overview](http://www.rubydoc.info/gems/yard/file/docs/Tags.md).
Add the following to your Gemfile to use `puppet-strings`:
### Rake tasks
```ruby
gem 'puppet-strings', :git => 'https://github.com/puppetlabs/puppet-strings.git'
```
You can use Puppet Strings rake tasks to generate documentation with additional options or to make your generated docs available on [GitHub Pages](https://pages.github.com/).
In your `Rakefile`, add the following to use the `puppet-strings` tasks:
The `strings:generate` and `strings:gh_pages:update` tasks are available in `puppet-strings/tasks`.
```ruby
First, update your Gemfile and your Rakefile.:
1. Add the following to your Gemfile to use `puppet-strings`:
```ruby
gem 'puppet-strings'
```
2. Add the following to your `Rakefile` to use the `puppet-strings` tasks:
```ruby
require 'puppet-strings/tasks'
```
```
Adding this `require` automatically creates the Rake tasks below.
The `strings:generate` task can be used to generate documentation:
#### Generate documentation with additional options
Use the `strings:generate` task to generate documentation:
```
$ rake strings:generate
```
The task accepts the following parameters:
This command behaves exactly as `puppet strings generate`, but allows you to add the following parameters:
* `patterns`: the search patterns to use for finding files to document (defaults to `manifests/**/*.pp functions/**/*.pp types/**/*.pp lib/**/*.rb`).
* `debug`: enables debug output when set to `true`.
@ -405,49 +451,57 @@ The task accepts the following parameters:
* `markup`: the markup language to use (defaults to `markdown`).
* `yard_args`: additional arguments to pass to YARD.
An example of passing arguments to the `strings:generate` Rake task:
For example, the task below adds a search pattern, debugs output, backtraces errors, sets the markup language to `markdown`, and passes an additional YARD argument setting the readme file to `README.md`:
```
$ rake strings:generate\['**/*{.pp\,.rb}, true, true, markdown, --readme README.md']
```
The `strings:gh_pages:update` task will generate your Puppet Strings documentation to be made available via [GitHub Pages](https://pages.github.com/). It will:
#### Generate documentation on GitHub Pages
1. Create a `doc` directory in the root of your project
2. Check out the `gh-pages` branch of the current repository in the `doc` directory (it will create a branch if one does not already exist)
3. Generate strings documentation using the `strings:generate` task
4. Commit the changes and push them to the `gh-pages` branch **with the `--force` flag**
To generate Puppet Strings documentation and make it available on [GitHub Pages](https://pages.github.com/), use the `strings:gh_pages:update` task.
This task:
1. Creates a `doc` directory in the root of your project.
2. Checks out the `gh-pages` branch of the current repository in the `doc` directory (it creates a branch if one does not already exist).
3. Generates Strings documentation with the `strings:generate` task.
4. Commits the changes and pushes them to the `gh-pages` branch **with the `--force` flag**.
This task aims to keep the `gh-pages` branch up to date with the current code and uses the `-f` flag when pushing to the `gh-pages` branch.
***Please note this operation will be destructive if not used properly.***
Developing and Contributing
---------------------------
**Please note this operation is destructive if not used properly.**
### Additional Resources
Here are a few other good resources for getting started with documentation:
* [Module README Template](https://docs.puppet.com/puppet/latest/reference/modules_documentation.html)
* [YARD Getting Started Guide](http://www.rubydoc.info/gems/yard/file/docs/GettingStarted.md)
* [YARD Tags Overview](http://www.rubydoc.info/gems/yard/file/docs/Tags.md)
## Developing and Contributing
We love contributions from the community!
If you'd like to contribute to the strings module, check out [CONTRIBUTING.md](https://github.com/puppetlabs/puppet-strings/blob/master/CONTRIBUTING.md) to get information on the contribution process.
If you'd like to contribute to puppet-strings, check out [CONTRIBUTING.md](https://github.com/puppetlabs/puppet-strings/blob/master/CONTRIBUTING.md) to get information on the contribution process.
Running Specs
-------------
### Running Specs
If you plan on developing features or fixing bugs in Puppet Strings, it is essential that you run specs before opening a pull request.
To run specs, simply execute the `spec` rake task:
To run specs, run the `spec` rake task:
$ bundle install --path .bundle/gems
$ bundle exec rake spec
Support
-------
## Support
Please log tickets and issues at our [JIRA tracker][JIRA]. A [mailing list](https://groups.google.com/forum/?fromgroups#!forum/puppet-users)
is available for asking questions and getting help from others.
Please log tickets and issues in our [JIRA tracker][JIRA]. A [mailing list](https://groups.google.com/forum/?fromgroups#!forum/puppet-users) is available for asking questions and getting help from others.
There is also an active #puppet channel on the Freenode IRC network.
We use semantic version numbers for our releases, and recommend that users stay as up-to-date as possible by upgrading to
We use semantic version numbers for our releases and recommend that users upgrade to
patch releases and minor releases as they become available.
Bug fixes and ongoing development will occur in minor releases for the current major version.
Security fixes will be ported to a previous major version on a best-effort basis, until the previous major version is no longer maintained.
Bug fixes and ongoing development will occur in minor releases for the current major version. Security fixes will be ported to a previous major version on a best-effort basis, until the previous major version is no longer maintained.