Testing your Documentation

Testing your documentation allows you to make sure it is in a consistent state. Doing this gives your users a better experience, and reduces stress around common issues as a writer.

This article by Anne Gentle is a good place to start to understand this concept.

Continuous Integration

The most useful tests are run on each commit of your project. This is called Continuous Integration, and is a common practice in the software development world.

We recommend checking out the following tools to get started:

  • Travis CI (GitHub only, free for open source)
  • AppVeyor (Windows support, free for open source)

Build Errors

The easiest automated check to do is to make sure your documentation builds properly. This requires simply running your documentation tool, and checking that it has properly built your documentation.

Most tools will return an error code of 0 if the process is successful. This means you should just be able to do a normal build of your tool, and your testing tool will know if it is successful or not.

If your build tool has a picky mode that flags warnings that might be problematic as well as errors, it might make sense to switch it on, but you’ll want to make sure that your documentation is in good shape before you do.

Style Guide Checking and Linting

Linters are tools that automatically verify specific rules against your code or documentation. This is useful for enforcing a style guide,or for catching commonly mitaken branding issues.

Here are a few links that might be interesting:


Vale is a syntax-aware linter for prose built for speed and extensibility.


It ships with the following default styles:

Several organizations have also created styles for use with Vale. Some of these styles have been collected in the following repository: https://github.com/testthedocs/vale-styles .

To configure Vale, follow the instructions in the README. If needed, install the vale binary as an executable in your $PATH, so you can run vale directly from the command line. For example, on UNIX/Linux systems, you can copy vale to the /usr/local/bin directory.

After installing Vale, run the following commands to check for proper installation:

$ vale

$ vale dc

If you see empty JSON in the output to the second command, you’ve successfully installed Vale.

Now to configure Vale, you’ll need a .vale or a .vale.ini configuration file. For some examples, see

While it’s possible to install the Vale configuration file in different locations, it may be most convenient to install it in the root directory of your target repository, as shown in the noted examples.

Once configured for your repository, you should be able to navigate to your repository path, and then run vale dc to confirm your configuration.

You can then apply Vale as a grammar linter directly to your source files, with a command like:

$ vale /path/to/someText.md

Hint: Vale even works with XML files, such as those in DocBook and DITA, as long as you’ve included *.xml in the Vale configuration file.