diff mbox series

[v2,6/6] docs: Add configuration documentation

Message ID 20180723070431.565-6-andrew.donnellan@au1.ibm.com
State Accepted
Headers show
Series [v2,1/6] CONTRIBUTING.md: Update references, add rustfmt information | expand

Commit Message

Andrew Donnellan July 23, 2018, 7:04 a.m. UTC
Add some basic configuration documentation that explains the config file
format.

Closes: #1 ("Documentation for usage and configuration")
Signed-off-by: Andrew Donnellan <andrew.donnellan@au1.ibm.com>
---
 docs/configuration.md | 169 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 169 insertions(+)
 create mode 100644 docs/configuration.md
diff mbox series

Patch

diff --git a/docs/configuration.md b/docs/configuration.md
new file mode 100644
index 000000000000..c7b3b8d66a8e
--- /dev/null
+++ b/docs/configuration.md
@@ -0,0 +1,169 @@ 
+Configuration
+=============
+
+snowpatch configuration files are in [TOML](https://en.wikipedia.org/wiki/TOML)
+format.
+
+Example configuration files can be found in the [examples](../examples)
+directory.
+
+A snowpatch configuration file contains three global configuration sections
+(tables, in TOML terms), `git`, `patchwork` and `jenkins`, and a `projects`
+section containing per-project configuration.
+
+
+Git Configuration
+-----------------
+
+The `git` section contains settings for the git SSH transport.
+
+Example:
+
+```
+[git]
+user = "git"
+public_key = "/home/ruscur/.ssh/id_rsa.pub"
+private_key = "/home/ruscur/.ssh/id_rsa"
+```
+
+- `user`: git SSH username (Currently, snowpatch only supports a single git
+  username for all git remotes - this will be addressed in future.)
+
+- `public_key`: path to SSH public key, usually `~/.ssh/id_rsa.pub` (optional)
+
+- `private_key`: path to SSH private key, usually `~/.ssh/id_rsa`
+
+- `passphrase`: passphrase for SSH private key (optional)
+
+Patchwork Configuration
+-----------------------
+
+The `patchwork` section contains settings for the Patchwork instance being
+monitored.
+
+Example:
+
+```
+[patchwork]
+url = "https://russell.cc/patchwork"
+port = 443 # optional
+user = "ruscur"
+pass = "banana"
+polling_interval = 10 # polling interval in minutes
+```
+
+- `url`: base URL of the Patchwork instance
+
+- `port`: port number (optional)
+
+- `user`: Patchwork username (must be used in conjuction with `pass`)
+
+- `pass`: Patchwork password (must be used in conjuction with `user`)
+
+- `token`: Patchwork API token (can be used instead of `user`/`pass`)
+
+- `polling_interval`: Patchwork polling interval, in minutes
+
+
+Jenkins Configuration
+---------------------
+
+The `jenkins` section contains settings for the Jenkins instance being used for
+builds.
+
+Example:
+
+```
+[jenkins]
+url = "https://jenkins.ozlabs.ibm.com"
+port = 443
+username = "patchwork"
+token = "33333333333333333333333333333333"
+```
+
+- `url`: base URL of the Jenkins instance
+
+- `port`: port number (optional)
+
+- `username`: Jenkins username (optional, must be used in conjunction with
+  `token`)
+
+- `token`: Jenkins API token (optional, must be used in conjunction with
+  `username`)
+
+
+Project Configuration
+---------------------
+
+The `projects` section consists of subsections for each project, which must be
+named `project.PROJECT_NAME`, where `PROJECT_NAME` corresponds to the short name
+("linkname") of the project in Patchwork.
+
+Within each project subsection, there is an array called `jobs` which consists
+of a table for each Jenkins job that should executed.
+
+Example:
+
+```
+    [projects.linuxppc-dev]
+    repository = "/home/ruscur/Documents/linux"
+    branches = ["master", "powerpc-next"]
+    # test_all_branches defaults to true
+    remote_name = "github"
+    remote_uri = "git@github.com:ruscur/linux.git"
+    push_results = false
+
+        [[projects.linuxppc-dev.jobs]]
+        job = "linux-build-manual"
+        remote = "GIT_REPO"
+        branch = "GIT_REF"
+        artifact = "snowpatch.txt"
+        hefty = true
+        DEFCONFIG_TO_USE = "pseries_le_defconfig"
+
+        [[projects.linuxppc-dev.jobs]]
+        job = "linux-build-manual"
+        remote = "GIT_REPO"
+        branch = "GIT_REF"
+        artifact = "snowpatch.txt"
+        hefty = false
+        DEFCONFIG_TO_USE = "ppc64le_defconfig"
+```
+
+- `repository`: path to local clone of git repository
+
+- `branches`: a list of base branches (as defined by the local git repository)
+  that patches should be tested against
+
+- `test_all_branches`: if true, each patch will be tested against all base
+  branches. If false, a patch will only be tested against the first base branch
+  to which it successfully applies. (Optional, defaults to true)
+
+- `remote_name`: the name of the remote, as defined in the local git repository,
+  to which branches should be pushed so that the Jenkins server can pull them
+
+- `remote_uri`: the URI of the remote
+
+- `push_results`: whether test results should be pushed to Patchwork for this project
+
+Individual jobs contain the following:
+
+- `job`: the name of the Jenkins job to run
+
+- `title`: title of the test which will appear in Patchwork (Optional, defaults
+  to job name)
+
+- `remote`: the name of the Jenkins build parameter in which the URI of the git
+  remote will be filled
+
+- `branch`: the name of the Jenkins build parameter in which the name of the git
+  branch to which the patch has been applied will be filled
+
+- `hefty`: whether this job is a "hefty" test. Hefty tests will only be run on
+  the final patch of a series, while non-hefty tests will be run on every patch
+  in the series. (Optional, defaults to false)
+
+- `warn_on_fail`: if true, this job will return a warning rather than a failure
+  if it fails (Optional, defaults to false)
+
+- Any further parameters will be passed to Jenkins as build parameters
\ No newline at end of file