From 950d6a0b97efabbf08c75d3e545d305bf20fc3bd Mon Sep 17 00:00:00 2001 From: axherrm Date: Fri, 15 Dec 2023 15:35:11 +0100 Subject: [PATCH] remove multiple branches deployment --- ...ontinuous-deployment-multiple-branches.yml | 108 ++++++++++++++++++ .github/workflows/continuous-deployment.yml | 84 ++------------ 2 files changed, 119 insertions(+), 73 deletions(-) create mode 100644 .github/workflows/continuous-deployment-multiple-branches.yml diff --git a/.github/workflows/continuous-deployment-multiple-branches.yml b/.github/workflows/continuous-deployment-multiple-branches.yml new file mode 100644 index 0000000..31b050f --- /dev/null +++ b/.github/workflows/continuous-deployment-multiple-branches.yml @@ -0,0 +1,108 @@ +#name: Continuous Deployment +# +#on: +# push: +# branches: +# - "**" +# +## Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages +#permissions: +# contents: read +# pages: write +# id-token: write +# actions: read +# +## Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued. +#concurrency: +# group: "pages" +# cancel-in-progress: true +# +#jobs: +# build_matrix: +# runs-on: ubuntu-latest +# outputs: +# json_branches: ${{ steps.generate-matrix.outputs.json_branches }} +# steps: +# - uses: actions/checkout@v4 +# with: +# fetch-depth: 0 +# - name: Generate Matrix +# id: generate-matrix +# run: | +# branches=($(git branch -r | cut -c 3- | sed 's/origin\///g')) +# json_branches=$(printf '%s\n' "${branches[@]}" | jq -R . | jq -s -c .) +# echo "json_branches=${json_branches}" >> $GITHUB_OUTPUT +# +# build: +# runs-on: ubuntu-latest +# name: Build +# needs: +# - build_matrix +# strategy: +# matrix: +# branch: ${{ fromJSON(needs.build_matrix.outputs.json_branches) }} +# steps: +# - uses: actions/checkout@v4 +# with: +# ref: ${{ matrix.branch }} +# - uses: actions/setup-node@v4 +# with: +# node-version: 20 +# - name: Build +# run: | +# npm install +# npm run build +# - uses: actions/upload-artifact@v3 +# with: +# name: ${{ strategy.job-index }} +# path: dist/cv/browser/ +## - name: Build +## run: | +## git for-each-ref --shell \ +## --format='git checkout \ +## refs/heads/ +# +# deploy: +# runs-on: ubuntu-latest +# name: Deploy +# environment: +# name: github-pages +# url: ${{ steps.deployment.outputs.page_url }} +# needs: +# - build_matrix +# - build +# steps: +# - uses: actions/checkout@v4 +# with: +# fetch-depth: 0 +# - name: Setup Pages +# uses: actions/configure-pages@v3 +# - run: gh run download ${{ vars.GITHUB_RUN_ID }} --dir branches +# env: +# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} +# +# - name: Create public folder +# run: | +# mkdir public +# mv .github/workflows/index.html ./public/index.html +# cd public +# branches=$(echo '${{ needs.build_matrix.outputs.json_branches }}' | jq -r '.[]') +# i=0 +# for branch in ${branches} +# do +# mkdir -p -- $branch +# mv ../branches/$i/* ./$branch +# +# echo "
  • ${branch}
  • " >> index.html +# +# i=$((i+1)) +# done +# cat ../.github/workflows/index_suffix.html >> index.html +# ls -lR +# - name: Upload artifact +# uses: actions/upload-pages-artifact@v2 +# with: +# path: ./public/ +# - name: Deploy to GitHub Pages +# id: deployment +# uses: actions/deploy-pages@v2 diff --git a/.github/workflows/continuous-deployment.yml b/.github/workflows/continuous-deployment.yml index 7fbbf95..b215f5b 100644 --- a/.github/workflows/continuous-deployment.yml +++ b/.github/workflows/continuous-deployment.yml @@ -3,14 +3,13 @@ name: Continuous Deployment on: push: branches: - - "**" + - main # Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages permissions: contents: read pages: write id-token: write - actions: read # Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued. concurrency: @@ -18,91 +17,30 @@ concurrency: cancel-in-progress: true jobs: - build_matrix: + build-and-deploy: runs-on: ubuntu-latest - outputs: - json_branches: ${{ steps.generate-matrix.outputs.json_branches }} - steps: - - uses: actions/checkout@v4 - with: - fetch-depth: 0 - - name: Generate Matrix - id: generate-matrix - run: | - branches=($(git branch -r | cut -c 3- | sed 's/origin\///g')) - json_branches=$(printf '%s\n' "${branches[@]}" | jq -R . | jq -s -c .) - echo "json_branches=${json_branches}" >> $GITHUB_OUTPUT - - build: - runs-on: ubuntu-latest - name: Build - needs: - - build_matrix - strategy: - matrix: - branch: ${{ fromJSON(needs.build_matrix.outputs.json_branches) }} + name: Build & Deploy + environment: + name: github-pages + url: ${{ steps.deployment.outputs.page_url }} steps: - - uses: actions/checkout@v4 - with: - ref: ${{ matrix.branch }} + - uses: actions/checkout@v3 - uses: actions/setup-node@v4 with: + # Version Spec of the version to use in SemVer notation. + # It also emits such aliases as lts, latest, nightly and canary builds + # Examples: 12.x, 10.15.1, >=10.15.0, lts/Hydrogen, 16-nightly, latest, node node-version: 20 - name: Build run: | npm install npm run build - - uses: actions/upload-artifact@v3 - with: - name: ${{ strategy.job-index }} - path: dist/cv/browser/ -# - name: Build -# run: | -# git for-each-ref --shell \ -# --format='git checkout \ -# refs/heads/ - - deploy: - runs-on: ubuntu-latest - name: Deploy - environment: - name: github-pages - url: ${{ steps.deployment.outputs.page_url }} - needs: - - build_matrix - - build - steps: - - uses: actions/checkout@v4 - with: - fetch-depth: 0 - name: Setup Pages uses: actions/configure-pages@v3 - - run: gh run download ${{ vars.GITHUB_RUN_ID }} --dir branches - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - - - name: Create public folder - run: | - mkdir public - mv .github/workflows/index.html ./public/index.html - cd public - branches=$(echo '${{ needs.build_matrix.outputs.json_branches }}' | jq -r '.[]') - i=0 - for branch in ${branches} - do - mkdir -p -- $branch - mv ../branches/$i/* ./$branch - - echo "
  • ${branch}
  • " >> index.html - - i=$((i+1)) - done - cat ../.github/workflows/index_suffix.html >> index.html - ls -lR - name: Upload artifact uses: actions/upload-pages-artifact@v2 with: - path: ./public/ + path: ./dist/cv/browser/ - name: Deploy to GitHub Pages id: deployment uses: actions/deploy-pages@v2