mirror of https://github.com/fluxcd/flux2.git
51 lines
3.2 KiB
Markdown
51 lines
3.2 KiB
Markdown
2 years ago
|
# Flux GitHub Workflows
|
||
|
|
||
|
## End-to-end Testing
|
||
|
|
||
|
The e2e workflows run a series of tests to ensure that the Flux CLI and
|
||
|
the GitOps Toolkit controllers work well all together.
|
||
|
The tests are written in Go, Bash, Make and Terraform.
|
||
|
|
||
|
| Workflow | Jobs | Runner | Role |
|
||
|
|--------------------|----------------------|----------------|-----------------------------------------------|
|
||
|
| e2e.yaml | e2e-amd64-kubernetes | GitHub Ubuntu | integration testing with Kubernetes Kind<br/> |
|
||
|
| e2e-arm64.yaml | e2e-arm64-kubernetes | Equinix Ubuntu | integration testing with Kubernetes Kind<br/> |
|
||
|
| e2e-bootstrap.yaml | e2e-boostrap-github | GitHub Ubuntu | integration testing with GitHub API<br/> |
|
||
|
| e2e-azure.yaml | e2e-amd64-aks | GitHub Ubuntu | integration testing with Azure API<br/> |
|
||
|
| scan.yaml | scan-fossa | GitHub Ubuntu | license scanning<br/> |
|
||
|
| scan.yaml | scan-snyk | GitHub Ubuntu | vulnerability scanning<br/> |
|
||
|
| scan.yaml | scan-codeql | GitHub Ubuntu | vulnerability scanning<br/> |
|
||
|
|
||
|
## Components Update
|
||
|
|
||
|
The components update workflow scans the GitOps Toolkit controller repositories for new releases,
|
||
|
amd when it finds a new controller version, the workflow performs the following steps:
|
||
|
- Updates the controller API package version in `go.mod`.
|
||
|
- Patches the controller CRDs version in the `manifests/crds` overlay.
|
||
|
- Patches the controller Deployment version in `manifests/bases` overlay.
|
||
|
- Opens a Pull Request against the `main` branch.
|
||
|
- Triggers the e2e test suite to run for the opened PR.
|
||
|
|
||
|
|
||
|
| Workflow | Jobs | Runner | Role |
|
||
|
|-------------|-------------------|---------------|-----------------------------------------------------|
|
||
|
| update.yaml | update-components | GitHub Ubuntu | update the GitOps Toolkit APIs and controllers<br/> |
|
||
|
|
||
|
## Release
|
||
|
|
||
|
The release workflow is triggered by a semver Git tag and performs the following steps:
|
||
|
- Generates the Flux install manifests (YAML).
|
||
|
- Generates the OpenAPI validation schemas for the GitOps Toolkit CRDs (JSON).
|
||
|
- Generates a Software Bill of Materials (SPDX JSON).
|
||
|
- Builds the Flux CLI binaries and the multi-arch container images.
|
||
|
- Pushes the container images to GitHub Container Registry and DockerHub.
|
||
|
- Signs the sbom, the binaries checksum and the container images with Cosign and GitHub OIDC.
|
||
|
- Uploads the sbom, binaries, checksums and install manifests to GitHub Releases.
|
||
|
- Pushes the install manifests as OCI artifacts to GitHub Container Registry and DockerHub.
|
||
|
- Signs the OCI artifacts with Cosign and GitHub OIDC.
|
||
|
|
||
|
| Workflow | Jobs | Runner | Role |
|
||
|
|--------------|------------------------|---------------|------------------------------------------------------|
|
||
|
| release.yaml | release-flux-cli | GitHub Ubuntu | build, push and sign the CLI release artifacts<br/> |
|
||
|
| release.yaml | release-flux-manifests | GitHub Ubuntu | build, push and sign the Flux install manifests<br/> |
|