From 545aa0a2e10c91054ff662415b5a78d71e7ea0e1 Mon Sep 17 00:00:00 2001 From: Toby Bellwood Date: Wed, 27 Mar 2024 10:54:07 +1100 Subject: [PATCH 1/2] fix: don't run Jenkins on doc/ branches and PRs --- Jenkinsfile | 63 ++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 62 insertions(+), 1 deletion(-) diff --git a/Jenkinsfile b/Jenkinsfile index 875d575223..caac090cdb 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -1,3 +1,5 @@ +def skipRemainingStages = false + pipeline { agent { label 'lagoon' } environment { @@ -20,6 +22,20 @@ pipeline { sh 'env' } } + stage ('skip on docs commit') { + when { + anyOf { + changeRequest branch: 'docs\\/.*', comparator: 'REGEXP' + branch pattern: "docs\\/.*", comparator: "REGEXP" + } + } + steps { + script { + skipRemainingStages = true + echo "Docs only update, no build needed." + } + } + } // in order to have the newest images from upstream (with all the security // updates) we clean our local docker cache on tag deployments // we don't do this all the time to still profit from image layer caching @@ -28,12 +44,20 @@ pipeline { stage ('clean docker image cache') { when { buildingTag() + expression { + !skipRemainingStages + } } steps { sh script: "docker image prune -af", label: "Pruning images" } } stage ('build and push images') { + when { + expression { + !skipRemainingStages + } + } environment { PASSWORD = credentials('amazeeiojenkins-dockerhub-password') } @@ -46,11 +70,21 @@ pipeline { } } stage ('show trivy scan results') { + when { + expression { + !skipRemainingStages + } + } steps { sh script: "cat scan.txt", label: "Display scan results" } } stage ('setup test cluster') { + when { + expression { + !skipRemainingStages + } + } parallel { stage ('0: setup test cluster') { steps { @@ -72,6 +106,11 @@ pipeline { } } stage ('run first test suite') { + when { + expression { + !skipRemainingStages + } + } parallel { stage ('1: run first test suite') { steps { @@ -106,6 +145,11 @@ pipeline { } } stage ('run second test suite') { + when { + expression { + !skipRemainingStages + } + } parallel { stage ('2: run second test suite') { steps { @@ -126,6 +170,11 @@ pipeline { } } stage ('run third test suite') { + when { + expression { + !skipRemainingStages + } + } parallel { stage ('3: run third test suite') { steps { @@ -146,11 +195,14 @@ pipeline { } } stage ('push images to testlagoon/* with :latest tag') { - when { + when { branch 'main' not { environment name: 'SKIP_IMAGE_PUBLISH', value: 'true' } + expression { + !skipRemainingStages + } } environment { PASSWORD = credentials('amazeeiojenkins-dockerhub-password') @@ -166,6 +218,9 @@ pipeline { not { environment name: 'SKIP_IMAGE_PUBLISH', value: 'true' } + expression { + !skipRemainingStages + } } environment { TOKEN = credentials('git-amazeeio-helmfile-ci-trigger') @@ -180,6 +235,9 @@ pipeline { not { environment name: 'SKIP_IMAGE_PUBLISH', value: 'true' } + expression { + !skipRemainingStages + } } environment { PASSWORD = credentials('amazeeiojenkins-dockerhub-password') @@ -195,6 +253,9 @@ pipeline { branch 'testing/scans' buildingTag() } + expression { + !skipRemainingStages + } } steps { sh script: 'make scan-images', label: "perform scan routines" From f47c37d04674d3bebbe7412bc4bebfe7be4e1201 Mon Sep 17 00:00:00 2001 From: Toby Bellwood Date: Wed, 27 Mar 2024 11:41:50 +1100 Subject: [PATCH 2/2] test: add mkdocs github action --- .github/workflows/test-mkdocs.yml | 38 +++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 .github/workflows/test-mkdocs.yml diff --git a/.github/workflows/test-mkdocs.yml b/.github/workflows/test-mkdocs.yml new file mode 100644 index 0000000000..463b9f7860 --- /dev/null +++ b/.github/workflows/test-mkdocs.yml @@ -0,0 +1,38 @@ +name: Test mkdocs +on: + push: + branches: + - 'docs/**' + pull_request: + branches: + - 'main' + paths: + - 'docs/**' + - 'mkdocs.yml' + - '.github/workflows/test-mkdocs.yml' + +jobs: + mkdocs: + runs-on: ubuntu-latest + steps: + - + name: Checkout PR + uses: actions/checkout@v4 + with: + fetch-depth: 0 + - + name: Install mkdocs and dependencies + run: | + pip install --upgrade pip + pip install mkdocs + pip install -r docs/requirements.txt + - + name: Check docs build ok in native mkdocs + run: | + mkdocs -V + mkdocs build -s + - + name: Check docs build ok with amazee.io mkdocs image + run: | + docker run --rm ghcr.io/amazeeio/mkdocs-material -V + docker run --rm -p 8000:8000 -v ${PWD}:/docs ghcr.io/amazeeio/mkdocs-material build -s