-
Notifications
You must be signed in to change notification settings - Fork 196
Testable Documentation
The vg build system is able to test examples in the Github wiki, and in the vg README. This is accomplished by adding the git version of the Github wiki as a submodule in /doc/wiki
in the vg repo, and using the txm
tool to execute test cases in the wiki Markdown files that are annotated with special comments
To add testable examples to a file:
-
Make sure that the file has this comment at the top, to tell the
txm
tool how to run the examples:<!-- !test program bash -eo pipefail -->
-
Write your example as a
``` ... ```
code block that is able to execute in the vg repo'stest
directory. -
Put a comment before the code block that tells
txm
to run it, and give it a name:<!-- !test check Your test description here -->
The
check
part says thattxm
should make sure that the command succeeds (i.e. exits with0
). Generally we use this because we want the commands in our documentation to run without error when users try to follow along. Tests that actually check for the correctness of the result might be better off as bash-tap or unit tests, rather than wiki examples. -
Get your changes into your local vg checkout's
doc/wiki
submodule. If using the online wiki editor:- Save your changes online.
- Go to
doc/wiki
in your checkout of the vg repo. - Run
git fetch
to download changes from the live wiki. - Inspect the changes with
git diff HEAD..origin/master
to make sure that nobody has been adding malicious test cases to our wiki. - Pull the changes into the submodule with
git merge origin/master
. - If you've ended up doing a non-fast-forward merge and creating a new commit, follow the steps below for editing locally to upload that commit.
If editing locally in
doc/wiki
:- Commit your changes on some branch (
mybranch
) within thedoc/wiki
submodule. - Make sure you have the SSH version of the wiki remote added within the
doc/wiki
submodule:git remote add upstream [email protected]:vgteam/vg.wiki.git
- Run
git push upstream mybranch:master
from within thedoc/wiki
submodule. - If Github rejects your push and you need to merge, follow the steps above for editing online to pull in changes from the online copy of the wiki.
-
Go back to the root of the vg repo.
-
Test your changes by running the script at
doc/test-docs.sh
. You can also test a single file, from thetest
directory, by running something liketxm --jobs 1 ../doc/wiki/Testable-Documentation.md
. -
When you have it working, add your changes with and
git add doc/wiki
, and commit your changes withgit commit
. -
Make a pull request to get your new test example merged.
Here is an example test as it appears on the wiki:
echo "racecar" | rev
And here is the code used to create it:
<!-- !test check Can run a trivial test -->
```
echo "racecar" | rev
```