CI/CD Pipeline
Times
- infrastructure "emergency service":
- Johannes: Monday, Friday
- Filip: Wednesday
- Richard: Tuesday, Thursday
 
- infrastructure maintenance window, fixed times when upgrades are done:
- Friday 8:00-10:00
 
Triggers
The pipeline will be executed only for pushes to Pull Requests and for pushes to master+dev.
If the pipeline fails and you think it is not the fault of your code, you can re-execute the pipeline by typing jenkins build please as a comment.
In any case (for person in charge see "emergency dienst" above):
- If there is already an open issue about it, ping the person in charge daily in this issue by posting the link to the failed build with @mention.
- Otherwise, please create a issue with the failing build log and assign the person in charge.
For users with login credentials for Jenkins, you can manually execute the pipeline for a branch or pull request via the Jenkins UI. Please ask if you want/need login data.
Succeeding Pushes
If you push to branches:
- Only the newest commit will be built. It does not matter if commits in between would pass.
- Builds of older pushes are aborted.
- Also jenkins build pleasewill abort previous builds and start the build again.
- Jenkins writes comments if MR pipelines were successful / failed.
- The latest MR build job will stay deployed on (https://mr.permaplant.net).
- The deployed branch and commit version can be seen on (https://mr.permaplant.net/version).
- The master and dev branch build when new commits get pushed to them.
Stages
Sanity stage
This stage performs rapid checks like pre-commit, migrations and schema building.
Local pre-commit currently does not perform the codespell hook, but it is performed in the pipeline. Cargo fmt, eslint and groovy linting is not performed through pre-commit.
Tests and Build
This is a parallel stage which fails fast (exits if one stage fails) or times out after 2 hours.
It can be subdivided in following categories:
Multiple parallel cargo stages
Standard cargo build, clippy, doc and test is performed here.
One sequential frontend stages
Frontend is built, tested, linted, format checked and additionally package.json version is verified to be up to date. Storybook and typedocs are also generated here.
One sequential mdbook stages
Mdbook is built, tested and links are checked.
Deploy MR
Every pull request will be deployed on a publicly available instance on mr.permaplant.net. Jenkins will acquires a lock before deploying to mr.permaplant.net and release it after finishing the E2E stage. This lock prevents other jobs to overwrite the deployment while we are performing E2E tests.
Since there is only one agent for MRs available, the last built MR wins.
E2E Tests
E2E tests are run on mr.permaplant.net. When a test times out, it is retried up to two times with a five second delay between retries.
Test reports and results can be found in the jobs artifacts.
Failed tests will generate videos and/or screenshots inside e2e/test-results/ in the jobs artifacts, depending on what failed.
The videos have to be downloaded to be viewed.
There is always a html report inside e2e/test-reports/ in the jobs artifacts and a cucumber report on a separate page.
Deploy Dev
The dev branch will be automatically deployed to dev.permaplant.net.
Deploy master
The master branch will be automatically deployed to master.permaplant.net.
Deploy Prod
There is a separate Jenkinsfile (/ci/Jenkinsfile.release) for this pipeline, which is only manually executable through Jenkins, it:
- uses the masterbranch (our release branch),
- runs only build and deploying stages (currently no testing), and
- deploys to www.permaplant.net.
See /.gitlab/issue_templates/Release.md for additional manual steps during the release.
Workspace Cleanup
The Jenkins Workspace Cleanup Plugin is available to help manage disk space by automatically cleaning build workspaces. This prevents workspace accumulation that can consume significant disk space on CI/CD servers.