name: Container & Helm chart on: [push] jobs: linting: name: Linting runs-on: dind-rootless steps: - name: Check out repository code uses: actions/checkout@v4 - name: yamllint uses: bewuethr/yamllint-action@v1 with: config-file: .yamllint.yaml semrel_dryrun: name: Semantic Release (Dry-run) runs-on: dind-rootless outputs: version: ${{ steps.sem_rel.outputs.version }} steps: - name: Check out repository code uses: actions/checkout@v4 - name: Setup Node uses: actions/setup-node@v3 with: node-version: 20 - name: Install dependencies run: | npm install \ semantic-release \ @semantic-release/commit-analyzer \ @semantic-release/exec - name: Semantic Release (dry-run) id: sem_rel run: | npx semantic-release \ --package @semantic-release/exec \ --package semantic-release \ --branches ${{ gitea.refname }} \ --tag-format 'v${version}' \ --dry-run \ --plugins @semantic-release/commit-analyzer,@semantic-release/exec \ --analyzeCommits @semantic-release/commit-analyzer \ --verifyRelease @semantic-release/exec \ --verifyReleaseCmd 'echo "version=${nextRelease.version}" >> $GITHUB_OUTPUT' env: GIT_CREDENTIALS: ${{ secrets.GIT_USERNAME }}:${{ secrets.GIT_APIKEY }} - name: Assert semantic release output run: | [[ -z "${{ steps.sem_rel.outputs.version }}" ]] && { echo 'No release tag - exiting'; exit 1 } || { echo 'Release tag set correctly: ${{ steps.sem_rel.outputs.version }}'; exit 0 } build_image: name: Kubernetes Bootstrap Appliance container: catthehacker/ubuntu:act-latest runs-on: dind-rootless needs: [semrel_dryrun, linting] steps: - name: Checkout uses: actions/checkout@v4 - name: Parse Kubernetes version uses: mikefarah/yq@master id: get_k8sversion with: cmd: yq '.components.clusterapi.workload.version.k8s' ansible/vars/metacluster.yml - name: Setup `packer` uses: hashicorp/setup-packer@main id: setup with: version: "latest" - name: Run `packer init` id: init run: packer init -upgrade ./packer - name: Run `packer validate` id: validate run: packer validate ./packer # run: | # packer validate \ # -e PACKER_LOG=1 \ # -only=vsphere-iso.bootstrap \ # -var vm_name=${{ gitea.job }}-${{ gitea.sha:0:10 }}-$(openssl rand -hex 3) \ # -var docker_username=${{ secrets.DOCKER_USERNAME }} \ # -var docker_password=${{ secrets.DOCKER_PASSWORD }} \ # -var repo_username=${{ secrets.REPO_USERNAME }} \ # -var repo_password=${{ secrets.REPO_PASSWORD }} \ # -var ssh_password=${{ secrets.SSH_PASSWORD }} \ # -var hv_password=${{ secrets.HV_PASSWORD }} \ # -var k8s_version=${{ steps.get_k8sversion.outputs.result }} \ # -var appliance_version=${{ needs.semrel_dryrun.outputs.version }} \ # ./packer - name: Run `packer build` run: | packer build \ -e PACKER_LOG=1 \ -only=vsphere-iso.bootstrap \ -var vm_name=${{ gitea.job }}-${{ gitea.sha:0:10 }}-$(openssl rand -hex 3) \ -var docker_username=${{ secrets.DOCKER_USERNAME }} \ -var docker_password=${{ secrets.DOCKER_PASSWORD }} \ -var repo_username=${{ secrets.REPO_USERNAME }} \ -var repo_password=${{ secrets.REPO_PASSWORD }} \ -var ssh_password=${{ secrets.SSH_PASSWORD }} \ -var hv_password=${{ secrets.HV_PASSWORD }} \ -var k8s_version=${{ steps.get_k8sversion.outputs.result }} \ -var appliance_version=${{ needs.semrel_dryrun.outputs.version }} \ ./packer # semrel: # name: Semantic Release # runs-on: dind-rootless # needs: [build_container, build_chart] # steps: # - name: Check out repository code # uses: actions/checkout@v3 # - name: Setup Node # uses: actions/setup-node@v3 # with: # node-version: 20 # - name: Install dependencies # run: | # npm install \ # semantic-release \ # @semantic-release/changelog \ # @semantic-release/commit-analyzer \ # @semantic-release/git \ # @semantic-release/release-notes-generator # - name: Semantic Release # run: | # npx semantic-release \ # --branches ${{ gitea.refname }} \ # --tag-format 'v${version}' \ # --plugins @semantic-release/commit-analyzer,@semantic-release/release-notes-generator,@semantic-release/changelog,@semantic-release/git # env: # GIT_CREDENTIALS: ${{ secrets.GIT_USERNAME }}:${{ secrets.GIT_APIKEY }}