ProwJob tester is a tool for testing changes to ProwJobs and scripts in the test-infra
repository which are under development. It uses the production Prow instance to run chosen ProwJobs with code from pull requests (PRs) without going through multiple cycles of new PRs, reviews, and merges. The whole development is done within one PR.
The workhorse for testing ProwJobs is a tool written in Go called pjtester
. It's available in the prow-tools
Docker image.
pjtester
is executed by the presubmit job pre-master-test-infra-pjtester
. This presubmit job is triggered when something changes under the test-infra
repository virtual path vpath/pjtester.yaml
.
It is configured by the run-if-changed option:
run_if_changed: "^(vpath/pjtester.yaml)"
pjtester
expects to find the configuration of the ProwJobs to tests under vpath/pjtester.yaml
.
By default, pjtester
disables all reporting for the ProwJob. That means no Slack messages and no status report on Github. To check the test results, consult the ProwStatus dashboard.
Details from pjtester.yaml
and from the ProwJob environment variables are used to construct the specification of the ProwJob to test. pjtester
uses the environment variables created by Prow for the presubmit job which identify the pull request and its commit hash in the test-infra
repository. The generated ProwJob to test then uses the test-infra
code from the pull request's head, ensuring that the latest code is under test.
For presubmit jobs, Prow requires the pull request's head SHA, pull request number, and pull request author set in the ProwJob refs. In the pjtester.yaml file
, you must specify a pull request number for a repository against which a tested Prow job is running. If you don't specify one, pjtester
will find a pull request for the master
branch (HEAD
) and use its details for the presubmit refs.
Finally, pjtester
creates the ProwJob on the production Prow instance. The ProwJob name for which you triggered the test is prefixed with {YOUR_GITHUB_USER}_test_of_prowjob_
.
Because the file vpath/pjtester.yaml
is used by pjtester
only to know the name of the ProwJob to test, it should not exist outside of the PR. This is why the pre-master-test-infra-vpathgurad
required context was added. Its simple task is to fail whenever the vpath
directory exists and to prevent the PR merge. As soon as the virtual path disappears from the PR, vpathguard
will allow for the PR merge.
ProwJob tester is a tool running on Prow. You need a working Prow instance to use it.
To make pjtester
work for you, you need to compile it and build an image with its binary included. This is done by the post-test-infra-prow-tools
ProwJob. It builds and pushes the prow-tools
image.
Next, you must add a presubmit job to trigger pjtester
execution. This is done by the pre-master-test-infra-pjtester
ProwJob.
The pjtester.yaml
file in the virtual path contains configuration parameters for the pjtester
tool:
Parameter name | Required | Description |
---|---|---|
pjNames | Yes | List containing the configuration of ProwJobs to test. |
pjNames.pjName | Yes | Name of the ProwJob to test. |
pjNames.pjPath | No | Path to the ProwJob definition. Must be relative from the kyma-project repository. If not provided, the default location for the kyma-project/test-infra repository is used. |
pjNames.report | No | Flag enabling reporting of the ProwJob status. The default value is false . |
prConfigs | No | Dictionary containing the numbers of the pull request on repositories other than test-infra . pjtester uses their code to test the ProwJobs. |
configPath | No | Location ot the Prow configuration. Defaults to the path used in kyma-project/test-infra . |
An example pjtester.yaml
file:
pjNames:
- pjName: "presubmit-test-job"
pjPath: "test-infra/development/tools/pkg/pjtester/test_artifacts/"
report: true
- pjName: "orphaned-disks-cleaner"
- pjName: "post-master-kyma-gke-integration"
prConfigs:
kyma-project:
kyma:
prNumber: 1212
configPath: "test-infra/prow/custom_config.yaml"
This is the Prow job tester flow:
- Create your feature branch with changes to scripts and/or ProwJobs.
- Create the
vpath/pjtester.yaml
file with the configuration of the ProwJob to test. - Create a PR with your changes.
- Watch the result of the
{YOUR_GITHUB_USER}_test_of_prowjob_{TESTED_PROWJOB'S_NAME}
Prow job. - Push new commits to the PR.
- Redo steps 4 and 5 until you're happy with the test results.
- Remove the virtual path directory from the PR.
- Merge your PR.
This was the main requirement for this tool. However, we did put some security in place. The pre-master-test-infra-pjtester
ProwJob is running on the trusted-workload
cluster, where it has everything it needs for succesful execution. Every ProwJob to test will be scheduled on the untrusted-workload
cluster, where no sensitive data exists. As for any other PR from a non-Kyma-organization member, every test must be triggered manually.
If you need new Secrets on workload clusters, ask the Neighbors team to create it for your tests.
pjtester
cannot wait till your new images are build on the PR. This still requires an extra commit after the image is placed in the registry.
The source code of pjtester
and its tests is located in test-infra/development/tools/pkg/pjtester
.
The main function used in the binary is located in test-infra/development/tools/cmd/pjtester
.
You can't use pjtester
to test changes to itself.