This repository contains some of the pipelines of Kogito project.
- Kogito Pipelines
- Kogito Repositories
- Kogito CI Status
- The different Kogito pipelines
- Configuration of pipelines
Apart from this repository, pipelines are also concerning those repositories:
- drools
- kogito-runtimes
- optaplanner
- kogito-apps
- kogito-examples
- kogito-images
- kogito-operator
- optaweb-employee-rostering
- optaweb-vehicle-routing
- optaplanner-quickstarts
You can check kogito organization repositories CI status from Chain Status webpage
Kogito has 2 main pipelines:
- Nightly pipeline
is a multibranch pipeline which is run daily on each active branch - Release pipeline
is a on-demand single pipeline job
More information can be found here.
This is a set of cleanup utils jobs.
In some of the Kogito repositories, you can find native checks. If that is the case, the pipeline can be found in .ci/jenkins/Jenkinsfile.native
.
A nightly check against Quarkus is done every night. Pipeline can be found in https://github.com/kiegroup/kogito-runtimes/blob/main/.ci/jenkins/Jenkinsfile.quarkus.
If the LTS check is enabled, then Quarkus and Native checks are also performed against LTS version of Quarkus (see config lts.quarkus_version
) and Quarkus native LTS builder image (see config lts.native_builder_image
).
PR checks are using the build-chain for artifacts and its configuration can be found in .ci folder.
They are run on both Jenkins and GHA with some slight differences.
There is one check per downstream repository. This allows parallelization and more flexibility in restart of a specific downstream repo.
kogito-images
is run only on Jenkins and is using its own .ci/jenkins/Jenkinsfile
.
kogito-operator
is run on another Jenkins and is using its own .ci/jenkins/Jenkinsfile
.
The jobs can be found into the {branch}/pullrequest
folder in Jenkins.
Each repository contains the needed DSL configuration (can be found in .ci/jenkins/dsl
) and will most of the time use the KogitoTemplate method createMultijobPRJobs
.
This will generate all the needed PR checks and make use of the Jenkinsfile.buildchain file.
Jenkins PR checks are of 3 different types:
- Simple build&test (automatic)
Regular testing - Native build&test (optional, can be launched with comment
jenkins run native
)
Test all native parts of the repository - LTS build&test (optional, can be launched with comment
jenkins run LTS
)
Test against quarkus LTS version (see above)
Each repository has a different yaml files in .github/workflows
folder to configure the workflow.
We are additionally using composite actions
to centralized most common steps used by the different Kogito repositories' jobs. You can check the different kind of composite actions we have available at .ci/actions
folder.
After the build, test results are parsed and logged using the action-surefire-report
action.
NOTE: test coverage analysis is executed only by Jenkins PR simple build&test and not while using GitHub action.
All pipelines can be found in kogito Jenkins folder.
More information can be found here.
Any message / error is sent to kogito-ci stream.
[branch] Project