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: code.spamasaurus.com/djpbessems/packer-extended:1.3.0 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: Set up packer uses: hashicorp/setup-packer@main id: setup with: version: "latest" - name: Prepare build environment id: init run: | packer init -upgrade ./packer ansible-galaxy collection install \ -r ansible/requirements.yml \ -p ./ansible/collections echo "BUILD_COMMIT=$(echo ${{ gitea.sha }} | cut -c 1-10)" >> $GITHUB_ENV echo "BUILD_SUFFIX=$(openssl rand -hex 3)" >> $GITHUB_ENV - name: Run `packer validate` id: validate run: | # BUILD_COMMIT=$(echo "${{ gitea.sha }}" | cut -c 1-10) # BUILD_SUFFIX=$(openssl rand -hex 3) packer validate \ -only=vsphere-iso.bootstrap \ -var vm_name=${{ gitea.run_number }}-${BUILD_COMMIT}-${BUILD_SUFFIX} \ -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: | # BUILD_COMMIT=$(echo "${{ gitea.sha }}" | cut -c 1-10) # BUILD_SUFFIX=$(openssl rand -hex 3) packer build \ -only=vsphere-iso.bootstrap \ -var vm_name=${{ gitea.run_number }}-${BUILD_COMMIT}-${BUILD_SUFFIX} \ -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 # env: # PACKER_LOG: 1 # 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 }}