Fork this repo under your GitHub account. After forking, clone the fork to your local machine: (replace your-username)
git clone https://github.com/your-username/ploigos-step-runner.git
⚠️ If you are running RHEL7 or older versions of Python: This project will need Python 3.3 or better to run. If you are running on RHEL7, you can invokepython3
in place ofpython
in the following commands.
cd ploigos-step-runner
python -m venv .venvs/psr-dev
source .venvs/psr-dev/bin/activate
python -m pip install --upgrade pip
python -m pip install -e '.[tests]'
You will need to run source .venvs/psr-dev/bin/activate
to activate the
development environment each time you start working in a new terminal session.
📓 Some tests require
mvn
command in your PATH. Install with brew/yum/dnf prior to running tests.
tox -e test
Or to run for just a particular implementer, and include the sections of code that you didn't cover
python3 -m pytest --cov --cov-report term-missing tests/step_implementers/package/test_maven_package.py
tox -e lint
tox
If you are updating the python documentation and want to generate locally this is how you do it.
tox -e docs
The easiest way to add a new step implementer is to copy an existing step implementer. The "example" step and it's implementers were created as examples for developers to copy and create their own implementers.
The source code for step implementers is under
./src/ploigos_step_runner/step_implementers/
. Each sub-directory represents a different step.
Each python files under a sub-directory is a step implementer for that step.
For example, ./src/ploigos_step_runner/step_implementers/unit-test/npm_test.py
is a step implementer
for the unit-test step that knows how to use the npm command to run unit tests.
Step implementers under the ./src/ploigos_step_runner/step_implementers/examples/
directory
are associated with the special "examples" step, which is not part of any workflow but is used
to organize and run example code. You can copy these examples as the basis for your own
step implementers.
To add a new step implementer:
-
Find example code you want to start with.
hello_shell.py
in theexamples
directory is a good starting point if your step implementer will run an external command. You could also copy a real step implementer as a starting point or start from scratch. -
Copy the example into a new python file under the appropriate sub directory. For example, if you are writing a step implementer for the package step that will compile intercal code, you should put it under the
package
directory and name it something likeintercal_package.py
. -
Create a file for your unit tests. You can copy the unit tests for the example. Put it in the appropriate sub directory of
./tests/
. The directory structure matches./src/
. Start the file name with 'test_', for example 'test_intercal_package.py`. If you like Test Driven Development, you can copy the structure of the test file and delete all the of old tests, writing new ones as you code. -
Modify the python code to implement the logic of your step. Continuing the intercal example, you would have to change the example code that runs the "echo" shell command and make it run the intercal compiler instead.
-
Be sure to run the unit tests and linter. PRs are not merged until the unit tests and lint checks pass and unit test coverage is 100%. If you are having trouble writing the unit tests, feel free to open a draft PR and ask for help!
-
During development, it is often useful to test the step by running the psr command directly. This saves time because you do not have to run a full pipeline to see if your python code behaves as expected outside of the unit tests. The next section explains how to do that.
-
Once the new step implementer is ready, create a Pull Request to contribute your code to the upstream project!
To run the HelloShell example step implementer:
- Create a psr.yaml file:
cat > psr.yaml << EOF
step-runner-config:
examples:
- implementer: HelloShell
config:
greeting-name: Folks
EOF
- Run PSR: The "examples" step is a special step used to execute example StepImplementers. It takes the place of a real step like "unit-test" or "create-container-image".
psr -s examples -c psr.yaml
-
Validate the output, both stdout and artifacts sections.
-
Delete the PSR working directory:
rm -r ./step-runner-working
⚠️ This step is important. If you need to re-run hello-world (or any step that has been run), you must remove the directory./step-runner-working
. See Troubleshooting.
- To execute a different implementer for the examples step, replace psr.yaml:
cat > psr.yaml << EOF
step-runner-config:
examples:
- implementer: HelloWorld
config:
greeting-name: Folks
EOF
This will use the simpler HelloWorld implementer instead of HelloShell. Re-run PSR and validate the output.
When developing a step implementer, it is often useful to have a real application that you can run the psr against. We maintain several specifically for that purpose:
- spring-petclinic is a Java application that uses Maven.
- reference-nodejs-npm is a NodeJS application that uses NPM.
- dotnet-app is a .NET application.
If you are testing another language or framework, use an application written for that language.
📓 If you're testing using a different repo, make sure to create a psr.yaml file in that root of that repo for PSR configurations.
Fatal error calling step (generate-metadata): Can not add duplicate StepResult for step (generate-metadata), sub step (Maven), and environment (None)
This error (and similar duplicate step errors) occurs when a step that was previously run is re-run. PSR expects a given step and sub-step to run only once. In an actual pipeline, this indicates an error. When developing step implementers, it is common to trigger this error when re-running steps to test changes.
To fix this, remove the ./step-runner-working directory:
rm -r ./step-runner-working