diff --git a/.github/pull_request_template.md b/.github/pull_request_template.md
new file mode 100644
index 000000000..7dc61f555
--- /dev/null
+++ b/.github/pull_request_template.md
@@ -0,0 +1 @@
+Please read [Submitting a Pull Request](https://github.com/pgbackrest/pgbackrest/blob/master/CONTRIBUTING.md#submitting-a-pull-request) before submitting.
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index ab8052b98..f55e87630 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -1,5 +1,17 @@
# pgBackRest Introduction Building a Development Environment Coding Testing Submitting a Pull Request
Contributing to pgBackRest
+## Table of Contents
+
+[Introduction](#introduction)
+
+[Building a Development Environment](#building-a-development-environment)
+
+[Coding](#coding)
+
+[Testing](#testing)
+
+[Submitting a Pull Request](#submitting-a-pull-request)
+
## Introduction
This documentation is intended to assist contributors to pgBackRest by outlining some basic steps and guidelines for contributing to the project.
@@ -10,7 +22,7 @@ Bug reports should be [submitted as issues](https://github.com/pgbackrest/pgback
You will always receive credit in the [release notes](http://www.pgbackrest.org/release.html) for your contributions.
-Coding standards are defined in [CODING.md](https://github.com/pgbackrest/pgbackrest/blob/master/CODING.md) and some important coding details and an example are provided in the [Coding](#coding) section below. At a minimum, unit tests must be written and run and the documentation generated before submitting a Pull Request; see the [Testing](#testing) section below for details.
+Coding standards are defined in [CODING.md](https://github.com/pgbackrest/pgbackrest/blob/master/CODING.md) and some important coding details and an example are provided in the [Coding](#coding) section below. At a minimum, unit tests must be written and run and the documentation generated before [submitting a Pull Request](#submitting-a-pull-request); see the [Testing](#testing) section below for details.
## Building a Development Environment
@@ -211,7 +223,7 @@ Examples of test runs are provided in the following sections. There are several
- `--vm-out` - displays the test output (helpful for monitoring the progress)
-- `--vm` - identifies the pre-built container when using Docker, otherwise the setting should be `none`
+- `--vm` - identifies the pre-built container when using Docker, otherwise the setting should be `none`. See [test.yml](https://github.com/pgbackrest/pgbackrest/blob/master.github/workflows/test.yml) for a list of valid vm codes noted by `param: test`.
For more options, run the test or documentation engine with the `--help` option:
```
@@ -229,7 +241,7 @@ pgbackrest/test/test.pl --vm=none --dry-run
--- output ---
- P00 INFO: test begin on aarch64 - log level info
+ P00 INFO: test begin on x86_64 - log level info
P00 INFO: configure build
P00 INFO: builds required: bin
--> P00 INFO: 72 tests selected
@@ -247,7 +259,7 @@ pgbackrest/test/test.pl --vm=none --vm-out --module=common --test=wait
--- output ---
- P00 INFO: test begin on aarch64 - log level info
+ P00 INFO: test begin on x86_64 - log level info
P00 INFO: autogenerate configure
P00 INFO: autogenerated version in configure.ac script: no changes
P00 INFO: autogenerated configure script: no changes
@@ -303,7 +315,7 @@ pgbackrest/test/test.pl --vm=none --module=postgres
--- output ---
- P00 INFO: test begin on aarch64 - log level info
+ P00 INFO: test begin on x86_64 - log level info
P00 INFO: autogenerate configure
P00 INFO: autogenerated version in configure.ac script: no changes
P00 INFO: autogenerated configure script: no changes
@@ -330,8 +342,8 @@ pgbackrest/test/test.pl --vm-build --vm=u20
--- output ---
- P00 INFO: test begin on aarch64 - log level info
- P00 INFO: Using cached pgbackrest/test:u20-base-20210718A image (d6c377617ac2c112b80a3c1f090345d54769ae1b) ...
+ P00 INFO: test begin on x86_64 - log level info
+ P00 INFO: Using cached pgbackrest/test:u20-base-20210717A image (d6c377617ac2c112b80a3c1f090345d54769ae1b) ...
P00 INFO: Building pgbackrest/test:u20-test image ...
P00 INFO: Build Complete
```
@@ -343,7 +355,7 @@ pgbackrest/test/test.pl --vm=u20 --module=mock --test=archive --run=2
--- output ---
- P00 INFO: test begin on aarch64 - log level info
+ P00 INFO: test begin on x86_64 - log level info
P00 INFO: autogenerate configure
P00 INFO: autogenerated version in configure.ac script: no changes
P00 INFO: autogenerated configure script: no changes
@@ -351,9 +363,9 @@ pgbackrest/test/test.pl --vm=u20 --module=mock --test=archive --run=2
P00 INFO: autogenerated C code: no changes
P00 INFO: cleanup old data and containers
P00 INFO: builds required: bin, bin host
- P00 INFO: build bin for u20 (/home/docker/test/bin/u20)
+ P00 INFO: build bin for u20 (/home/vagrant/test/bin/u20)
P00 INFO: bin dependencies have changed, rebuilding
- P00 INFO: build bin for none (/home/docker/test/bin/none)
+ P00 INFO: build bin for none (/home/vagrant/test/bin/none)
P00 INFO: bin dependencies have changed, rebuilding
P00 INFO: 1 test selected
@@ -397,7 +409,7 @@ Assuming that a test file already exists, new unit tests will either go in a new
// *****************************************************************************************************************************
if (testBegin("expireBackup()"))
{
- //--------------------------------------------------------------------------------------------------------------------------
+ // -------------------------------------------------------------------------------------------------------------------------
TEST_TITLE("manifest file removal");
```
@@ -436,6 +448,7 @@ Tests are run and results confirmed via macros that are described in [harnessTes
- `TEST_RESULT_VOID` - The function being tested returns a `void`. This is then usually followed by tests that ensure other actions occurred (e.g. a file was written to disk).
- `TEST_ERROR` / `TEST_ERROR_FMT` - Test that a specific error code was raised with specific wording.
+> **NOTE:** `HRN_*` macros should be used only for test setup and cleanup. `TEST_*` macros must be used for testing results.
#### Testing a log message
@@ -444,6 +457,7 @@ If a function being tested logs something with `LOG_WARN`, `LOG_INFO` or other `
TEST_RESULT_LOG(
"P00 WARN: WAL segment '000000010000000100000001' was not pushed due to error [25] and was manually skipped: error");
```
+In the above, `Pxx` indicates the process (P) and the process number (xx), e.g. P00, P01.
#### Testing using child process
@@ -524,6 +538,24 @@ Sometimes it is useful to look at files that were generated during the test. The
pgbackrest/test/test.pl --vm-out --module=command --test=check --run=1 --no-cleanup
```
+### Understanding Test Output
+
+The following is a small sample of a typical test output.
+```
+run 8 - expireTimeBasedBackup()
+
+run 8/1 ------------- L2285 no current backups
+ 000.002s L2298 empty backup.info
+ 000.009s 000.007s L2300 no backups to expire
+```
+**run 8 - expireTimeBasedBackup()** - indicates the run number (8) within the module and the parameter provided to testBegin, e.g. `testBegin("expireTimeBasedBackup()")`
+
+**run 8/1 ------------- L2285 no current backups** - this is the first test (1) in run 8 which is the `TEST_TITLE("no current backups");` at line number 2285.
+
+**000.002s L2298 empty backup.info** - the first number, 000.002s, is the time in seconds that the test started from the beginning of the run. L2298 is the line number of the test and `empty backup.info` is the test comment.
+
+**000.009s 000.007s L2300 no backups to expire** - again, 000.009s, is the time in seconds that the test started from the beginning of the run. The second number, 000.007s, is the run time of the **previous** test (i.e. `empty backup.info` test took 000.007 seconds to execute). L2300 is the line number of the test and `no backups to expire` is the test comment.
+
## Adding an Option
Options can be added to a command or multiple commands. Options can be configuration file only, command-line only or valid for both. Once an option is successfully added, `config.auto.*`, `define.auto.*` and `parse.auto.*` files will automatically be generated by the build system.
@@ -658,10 +690,44 @@ pgbackrest/doc/doc.pl --output=html --no-exe
```
The generated HTML files will be placed in the `doc/output/html` directory where they can be viewed locally in a browser.
-If Docker is installed, it will be used by the documentation generator to execute the code elements while building the documentation. `--no-cache` may be used to force a full build even when no code elements have changed since the last build. `--pre` will reuse the container definitions from the prior build and saves time during development.
+If Docker is installed, it will be used by the documentation generator to execute the code elements while building the documentation, therefore, the `--no-exe` should be omitted, (i.e. `pgbackrest/doc/doc.pl --output=html`). `--no-cache` may be used to force a full build even when no code elements have changed since the last build. `--pre` will reuse the container definitions from the prior build and saves time during development.
The containers created for documentation builds can be useful for manually testing or trying out new code or features. The following demonstrates building through just the `quickstart` section of the `user-guide` without encryption.
```
pgbackrest/doc/doc.pl --out=html --include=user-guide --require=/quickstart --var=encrypt=n --no-cache --pre
```
The resulting Docker containers can be listed with `docker ps` and the container can be entered with `docker exec doc-pg-primary bash`. Additionally, the `-u` option can be added for entering the container as a specific user (e.g. `postgres`).
+
+## Submitting a Pull Request
+
+Before submitting a Pull Request:
+
+- Does it meet the [coding standards](https://github.com/pgbackrest/pgbackrest/blob/master/CODING.md)?
+
+
+- Have [Unit Tests](#writing-a-unit-test) been written and [run](#running-a-unit-test) with 100% coverage?
+
+
+- If your submission includes changes to the help or online documentation, have the [help](#testing-the-help) and [documentation](#testing-the-documentation) tests been run?
+
+
+- Has it passed continuous integration testing? Simply renaming your branch with the appendix `-cig` and pushing it to your GitHub account will initiate GitHub Actions to run CI tests.
+
+
+When submitting a Pull Request:
+
+- Provide a short submission title.
+
+
+- Write a detailed comment to describe the purpose of your submission and any issue(s), if any, it is resolving; a link to the GitHub issue is also helpful.
+
+
+After submitting a Pull Request:
+
+- One or more reviewers will be assigned.
+
+
+- Respond to any issues (conversations) in GitHub but do not resolve the conversation; the reviewer is responsible for ensuring the issue raised has been resolved and marking the conversation resolved. It is helpful to supply the commit in your reply if one was submitted to fix the issue.
+
+
+Lastly, thank you for contributing to pgBackRest!
diff --git a/doc/xml/contributing.xml b/doc/xml/contributing.xml
index fe440f704..06570768e 100644
--- a/doc/xml/contributing.xml
+++ b/doc/xml/contributing.xml
@@ -47,6 +47,16 @@
+
none
none
. See test.yml for a list of valid vm codes noted by param: test
.For more options, run the test or documentation engine with the
void
. This is then usually followed by tests that ensure other actions occurred (e.g. a file was written to disk).HRN_*
macros should be used only for test setup and cleanup. TEST_*
macros must be used for testing results.In the above, Pxx
indicates the process (P) and the process number (xx), e.g. P00, P01.
The following is a small sample of a typical test output.
+ +run 8 - expireTimeBasedBackup() - indicates the run number (8) within the module and the parameter provided to testBegin, e.g. testBegin("expireTimeBasedBackup()")
run 8/1 ------------- L2285 no current backups - this is the first test (1) in run 8 which is the TEST_TITLE("no current backups");
at line number 2285.
000.002s L2298 empty backup.info - the first number, 000.002s, is the time in seconds that the test started from the beginning of the run. L2298 is the line number of the test and empty backup.info
is the test comment.
000.009s 000.007s L2300 no backups to expire - again, 000.009s, is the time in seconds that the test started from the beginning of the run. The second number, 000.007s, is the run time of the previous test (i.e. empty backup.info
test took 000.007 seconds to execute). L2300 is the line number of the test and no backups to expire
is the test comment.
The generated HTML files will be placed in the
If Docker is installed, it will be used by the documentation generator to execute the code elements while building the documentation.
If Docker is installed, it will be used by the documentation generator to execute the code elements while building the documentation, therefore, the pgbackrest/doc/doc.pl --output=html
).
The containers created for documentation builds can be useful for manually testing or trying out new code or features. The following demonstrates building through just the quickstart
section of the
The resulting Docker containers can be listed with docker ps
and the container can be entered with docker exec doc-pg-primary bash
. Additionally, the -u
option can be added for entering the container as a specific user (e.g. postgres
).
Before submitting a Pull Request:
+ +-cig
and pushing it to your GitHub account will initiate GitHub Actions to run CI tests.
+ When submitting a Pull Request:
+After submitting a Pull Request:
+ +Lastly, thank you for contributing to
Update contributing documentation and add pull request template.
+