mirror of
https://github.com/fluxcd/flux2.git
synced 2026-02-08 00:37:27 +00:00
Bumps the ci group with 6 updates: | Package | From | To | | --- | --- | --- | | [fluxcd/gha-workflows](https://github.com/fluxcd/gha-workflows) | `0.3.0` | `0.4.0` | | [actions/setup-go](https://github.com/actions/setup-go) | `5.5.0` | `6.0.0` | | [fluxcd/pkg](https://github.com/fluxcd/pkg) | `1.20.0` | `1.22.0` | | [github/codeql-action](https://github.com/github/codeql-action) | `3.29.11` | `3.30.3` | | [anchore/sbom-action](https://github.com/anchore/sbom-action) | `0.20.5` | `0.20.6` | | [sigstore/cosign-installer](https://github.com/sigstore/cosign-installer) | `3.9.2` | `3.10.0` | Updates `fluxcd/gha-workflows` from 0.3.0 to 0.4.0 - [Release notes](https://github.com/fluxcd/gha-workflows/releases) - [Commits](https://github.com/fluxcd/gha-workflows/compare/v0.3.0...v0.4.0) Updates `actions/setup-go` from 5.5.0 to 6.0.0 - [Release notes](https://github.com/actions/setup-go/releases) - [Commits](d35c59abb0...4469467582) Updates `fluxcd/pkg` from 1.20.0 to 1.22.0 - [Commits](7f090e9313...bf02f0a2d6) Updates `github/codeql-action` from 3.29.11 to 3.30.3 - [Release notes](https://github.com/github/codeql-action/releases) - [Changelog](https://github.com/github/codeql-action/blob/main/CHANGELOG.md) - [Commits](3c3833e0f8...192325c861) Updates `anchore/sbom-action` from 0.20.5 to 0.20.6 - [Release notes](https://github.com/anchore/sbom-action/releases) - [Changelog](https://github.com/anchore/sbom-action/blob/main/RELEASE.md) - [Commits](da167eac91...f8bdd1d8ac) Updates `sigstore/cosign-installer` from 3.9.2 to 3.10.0 - [Release notes](https://github.com/sigstore/cosign-installer/releases) - [Commits](d58896d6a1...d7543c93d8) --- updated-dependencies: - dependency-name: fluxcd/gha-workflows dependency-version: 0.4.0 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: ci - dependency-name: actions/setup-go dependency-version: 6.0.0 dependency-type: direct:production update-type: version-update:semver-major dependency-group: ci - dependency-name: fluxcd/pkg dependency-version: 1.22.0 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: ci - dependency-name: github/codeql-action dependency-version: 3.30.3 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: ci - dependency-name: anchore/sbom-action dependency-version: 0.20.6 dependency-type: direct:production update-type: version-update:semver-patch dependency-group: ci - dependency-name: sigstore/cosign-installer dependency-version: 3.10.0 dependency-type: direct:production update-type: version-update:semver-minor dependency-group: ci ... Signed-off-by: dependabot[bot] <support@github.com>
258 lines
9.6 KiB
YAML
258 lines
9.6 KiB
YAML
name: e2e
|
|
|
|
on:
|
|
workflow_dispatch:
|
|
push:
|
|
branches: [ 'main', 'release/**' ]
|
|
pull_request:
|
|
branches: [ 'main', 'release/**' ]
|
|
paths-ignore: [ 'docs/**', 'rfcs/**' ]
|
|
|
|
permissions:
|
|
contents: read
|
|
|
|
jobs:
|
|
e2e-amd64-kubernetes:
|
|
runs-on:
|
|
group: "Default Larger Runners"
|
|
labels: ubuntu-latest-16-cores
|
|
services:
|
|
registry:
|
|
image: registry:2
|
|
ports:
|
|
- 5000:5000
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
|
|
- name: Setup Go
|
|
uses: actions/setup-go@44694675825211faa026b3c33043df3e48a5fa00 # v6.0.0
|
|
with:
|
|
go-version: 1.25.x
|
|
cache-dependency-path: |
|
|
**/go.sum
|
|
**/go.mod
|
|
- name: Setup Kubernetes
|
|
uses: helm/kind-action@a1b0e391336a6ee6713a0583f8c6240d70863de3 # v1.12.0
|
|
with:
|
|
version: v0.30.0
|
|
cluster_name: kind
|
|
wait: 5s
|
|
config: .github/kind/config.yaml # disable KIND-net
|
|
# The versions below should target the oldest supported Kubernetes version
|
|
# Keep this up-to-date with https://endoflife.date/kubernetes
|
|
node_image: ghcr.io/fluxcd/kindest/node:v1.32.1-amd64
|
|
kubectl_version: v1.32.0
|
|
- name: Setup Calico for network policy
|
|
run: |
|
|
kubectl apply -f https://raw.githubusercontent.com/projectcalico/calico/v3.27.3/manifests/calico.yaml
|
|
- name: Setup Kustomize
|
|
uses: fluxcd/pkg/actions/kustomize@bf02f0a2d612cc07e0892166369fa8f63246aabb # main
|
|
- name: Run tests
|
|
run: make test
|
|
- name: Run e2e tests
|
|
run: TEST_KUBECONFIG=$HOME/.kube/config make e2e
|
|
- name: Check if working tree is dirty
|
|
run: |
|
|
if [[ $(git diff --stat) != '' ]]; then
|
|
git diff
|
|
echo 'run make test and commit changes'
|
|
exit 1
|
|
fi
|
|
- name: Build
|
|
run: make build-dev
|
|
- name: flux check --pre
|
|
run: |
|
|
./bin/flux check --pre
|
|
- name: flux install --manifests
|
|
run: |
|
|
./bin/flux install --manifests ./manifests/install/
|
|
- name: flux create secret
|
|
run: |
|
|
./bin/flux create secret git git-ssh-test \
|
|
--url ssh://git@github.com/stefanprodan/podinfo
|
|
./bin/flux create secret git git-https-test \
|
|
--url https://github.com/stefanprodan/podinfo \
|
|
--username=test --password=test
|
|
./bin/flux create secret helm helm-test \
|
|
--username=test --password=test
|
|
- name: flux create source git
|
|
run: |
|
|
./bin/flux create source git podinfo \
|
|
--url https://github.com/stefanprodan/podinfo \
|
|
--tag-semver=">=6.3.5"
|
|
- name: flux create source git export apply
|
|
run: |
|
|
./bin/flux create source git podinfo-export \
|
|
--url https://github.com/stefanprodan/podinfo \
|
|
--tag-semver=">=6.3.5" \
|
|
--export | kubectl apply -f -
|
|
./bin/flux delete source git podinfo-export --silent
|
|
- name: flux get sources git
|
|
run: |
|
|
./bin/flux get sources git
|
|
- name: flux get sources git --all-namespaces
|
|
run: |
|
|
./bin/flux get sources git --all-namespaces
|
|
- name: flux create kustomization
|
|
run: |
|
|
./bin/flux create kustomization podinfo \
|
|
--source=podinfo \
|
|
--path="./deploy/overlays/dev" \
|
|
--prune=true \
|
|
--interval=5m \
|
|
--health-check="Deployment/frontend.dev" \
|
|
--health-check="Deployment/backend.dev" \
|
|
--health-check-timeout=3m
|
|
- name: flux trace
|
|
run: |
|
|
./bin/flux trace frontend \
|
|
--kind=deployment \
|
|
--api-version=apps/v1 \
|
|
--namespace=dev
|
|
- name: flux reconcile kustomization --with-source
|
|
run: |
|
|
./bin/flux reconcile kustomization podinfo --with-source
|
|
- name: flux get kustomizations
|
|
run: |
|
|
./bin/flux get kustomizations
|
|
- name: flux get kustomizations --all-namespaces
|
|
run: |
|
|
./bin/flux get kustomizations --all-namespaces
|
|
- name: flux suspend kustomization
|
|
run: |
|
|
./bin/flux suspend kustomization podinfo
|
|
- name: flux resume kustomization
|
|
run: |
|
|
./bin/flux resume kustomization podinfo
|
|
- name: flux export
|
|
run: |
|
|
./bin/flux export source git --all
|
|
./bin/flux export kustomization --all
|
|
- name: flux delete kustomization
|
|
run: |
|
|
./bin/flux delete kustomization podinfo --silent
|
|
- name: flux create source helm
|
|
run: |
|
|
./bin/flux create source helm podinfo \
|
|
--url https://stefanprodan.github.io/podinfo
|
|
- name: flux create helmrelease --source=HelmRepository/podinfo
|
|
run: |
|
|
./bin/flux create hr podinfo-helm \
|
|
--target-namespace=default \
|
|
--source=HelmRepository/podinfo.flux-system \
|
|
--chart=podinfo \
|
|
--chart-version=">6.0.0 <7.0.0"
|
|
- name: flux create helmrelease --source=GitRepository/podinfo
|
|
run: |
|
|
./bin/flux create hr podinfo-git \
|
|
--target-namespace=default \
|
|
--source=GitRepository/podinfo \
|
|
--chart=./charts/podinfo
|
|
- name: flux reconcile helmrelease --with-source
|
|
run: |
|
|
./bin/flux reconcile helmrelease podinfo-git --with-source
|
|
- name: flux get helmreleases
|
|
run: |
|
|
./bin/flux get helmreleases
|
|
- name: flux get helmreleases --all-namespaces
|
|
run: |
|
|
./bin/flux get helmreleases --all-namespaces
|
|
- name: flux export helmrelease
|
|
run: |
|
|
./bin/flux export hr --all
|
|
- name: flux delete helmrelease podinfo-helm
|
|
run: |
|
|
./bin/flux delete hr podinfo-helm --silent
|
|
- name: flux delete helmrelease podinfo-git
|
|
run: |
|
|
./bin/flux delete hr podinfo-git --silent
|
|
- name: flux delete source helm
|
|
run: |
|
|
./bin/flux delete source helm podinfo --silent
|
|
- name: flux delete source git
|
|
run: |
|
|
./bin/flux delete source git podinfo --silent
|
|
- name: flux oci artifacts
|
|
run: |
|
|
./bin/flux push artifact oci://localhost:5000/fluxcd/flux:${{ github.sha }} \
|
|
--path="./manifests" \
|
|
--source="${{ github.repositoryUrl }}" \
|
|
--revision="${{ github.ref }}@sha1:${{ github.sha }}"
|
|
./bin/flux tag artifact oci://localhost:5000/fluxcd/flux:${{ github.sha }} \
|
|
--tag latest
|
|
./bin/flux list artifacts oci://localhost:5000/fluxcd/flux
|
|
- name: flux oci repositories
|
|
run: |
|
|
./bin/flux create source oci podinfo-oci \
|
|
--url oci://ghcr.io/stefanprodan/manifests/podinfo \
|
|
--tag-semver 6.3.x \
|
|
--interval 10m
|
|
./bin/flux create kustomization podinfo-oci \
|
|
--source=OCIRepository/podinfo-oci \
|
|
--path="./" \
|
|
--prune=true \
|
|
--interval=5m \
|
|
--target-namespace=default \
|
|
--wait=true \
|
|
--health-check-timeout=3m
|
|
./bin/flux reconcile source oci podinfo-oci
|
|
./bin/flux suspend source oci podinfo-oci
|
|
./bin/flux get sources oci
|
|
./bin/flux resume source oci podinfo-oci
|
|
./bin/flux export source oci podinfo-oci
|
|
./bin/flux delete ks podinfo-oci --silent
|
|
./bin/flux delete source oci podinfo-oci --silent
|
|
- name: flux create tenant
|
|
run: |
|
|
./bin/flux create tenant dev-team --with-namespace=apps
|
|
./bin/flux -n apps create source helm podinfo \
|
|
--url https://stefanprodan.github.io/podinfo
|
|
./bin/flux -n apps create hr podinfo-helm \
|
|
--source=HelmRepository/podinfo \
|
|
--chart=podinfo \
|
|
--chart-version="6.3.x" \
|
|
--service-account=dev-team
|
|
- name: flux2-kustomize-helm-example
|
|
run: |
|
|
./bin/flux create source git flux-system \
|
|
--url=https://github.com/fluxcd/flux2-kustomize-helm-example \
|
|
--branch=main \
|
|
--ignore-paths="./clusters/**/flux-system/" \
|
|
--recurse-submodules
|
|
./bin/flux create kustomization flux-system \
|
|
--source=flux-system \
|
|
--path=./clusters/staging
|
|
kubectl -n flux-system wait kustomization/infra-controllers --for=condition=ready --timeout=5m
|
|
kubectl -n flux-system wait kustomization/apps --for=condition=ready --timeout=5m
|
|
kubectl -n podinfo wait helmrelease/podinfo --for=condition=ready --timeout=5m
|
|
- name: flux tree
|
|
run: |
|
|
./bin/flux tree kustomization flux-system | grep Service/podinfo
|
|
- name: flux events
|
|
run: |
|
|
./bin/flux -n flux-system events --for Kustomization/apps | grep 'HelmRelease/podinfo'
|
|
./bin/flux -n podinfo events --for HelmRelease/podinfo | grep 'podinfo.v1'
|
|
- name: flux stats
|
|
run: |
|
|
./bin/flux stats -A
|
|
- name: flux check
|
|
run: |
|
|
./bin/flux check
|
|
- name: flux migrate
|
|
run: |
|
|
./bin/flux migrate
|
|
- name: flux version
|
|
run: |
|
|
./bin/flux version
|
|
- name: flux uninstall
|
|
run: |
|
|
./bin/flux uninstall --silent
|
|
- name: Debug failure
|
|
if: failure()
|
|
run: |
|
|
kubectl version --client
|
|
kubectl -n flux-system get all
|
|
kubectl -n flux-system describe pods
|
|
kubectl -n flux-system get kustomizations -oyaml
|
|
kubectl -n flux-system logs deploy/source-controller
|
|
kubectl -n flux-system logs deploy/kustomize-controller
|