mirror of
				https://github.com/kata-containers/kata-containers.git
				synced 2025-10-21 20:08:54 +00:00 
			
		
		
		
	This is a commit that's a pre-req for #6826, as that PR will merge log-parser-rs into kata-ctl, but that will result in a CI breakage. So, let's deal with the CI changes here, thanks to GHA and our favourite `pull_request_target` event, unblocking that PR to be merged. Fixes: #6797 (not really, but related). Signed-off-by: Fabiano Fidêncio <fabiano.fidencio@intel.com>
		
			
				
	
	
		
			141 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			141 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| name: CI | Build kata-static tarball for amd64
 | |
| on:
 | |
|   workflow_call:
 | |
|     inputs:
 | |
|       stage:
 | |
|         required: false
 | |
|         type: string
 | |
|         default: test
 | |
|       tarball-suffix:
 | |
|         required: false
 | |
|         type: string
 | |
|       push-to-registry:
 | |
|         required: false
 | |
|         type: string
 | |
|         default: no
 | |
|       commit-hash:
 | |
|         required: false
 | |
|         type: string
 | |
|       target-branch:
 | |
|         required: false
 | |
|         type: string
 | |
|         default: ""
 | |
| 
 | |
| jobs:
 | |
|   build-asset:
 | |
|     runs-on: ubuntu-latest
 | |
|     strategy:
 | |
|       matrix:
 | |
|         asset:
 | |
|           - agent
 | |
|           - agent-opa
 | |
|           - agent-ctl
 | |
|           - cloud-hypervisor
 | |
|           - cloud-hypervisor-glibc
 | |
|           - firecracker
 | |
|           - kata-ctl
 | |
|           - kernel
 | |
|           - kernel-sev
 | |
|           - kernel-dragonball-experimental
 | |
|           - kernel-tdx-experimental
 | |
|           - kernel-nvidia-gpu
 | |
|           - kernel-nvidia-gpu-snp
 | |
|           - kernel-nvidia-gpu-tdx-experimental
 | |
|           - nydus
 | |
|           - ovmf
 | |
|           - ovmf-sev
 | |
|           - qemu
 | |
|           - qemu-snp-experimental
 | |
|           - qemu-tdx-experimental
 | |
|           - stratovirt
 | |
|           - rootfs-image
 | |
|           - rootfs-image-tdx
 | |
|           - rootfs-initrd
 | |
|           - rootfs-initrd-mariner
 | |
|           - rootfs-initrd-sev
 | |
|           - runk
 | |
|           - shim-v2
 | |
|           - tdvf
 | |
|           - trace-forwarder
 | |
|           - virtiofsd
 | |
|         stage:
 | |
|           - ${{ inputs.stage }}
 | |
|         exclude:
 | |
|           - asset: agent
 | |
|             stage: release
 | |
|           - asset: agent-opa
 | |
|             stage: release
 | |
|           - asset: cloud-hypervisor-glibc
 | |
|             stage: release
 | |
|     steps:
 | |
|       - name: Login to Kata Containers quay.io
 | |
|         if: ${{ inputs.push-to-registry == 'yes' }}
 | |
|         uses: docker/login-action@v2
 | |
|         with:
 | |
|           registry: quay.io
 | |
|           username: ${{ secrets.QUAY_DEPLOYER_USERNAME }}
 | |
|           password: ${{ secrets.QUAY_DEPLOYER_PASSWORD }}
 | |
| 
 | |
|       - uses: actions/checkout@v4
 | |
|         with:
 | |
|           ref: ${{ inputs.commit-hash }}
 | |
|           fetch-depth: 0 # This is needed in order to keep the commit ids history
 | |
| 
 | |
|       - name: Rebase atop of the latest target branch
 | |
|         run: |
 | |
|           ./tests/git-helper.sh "rebase-atop-of-the-latest-target-branch"
 | |
|         env:
 | |
|           TARGET_BRANCH: ${{ inputs.target-branch }}
 | |
| 
 | |
|       - name: Build ${{ matrix.asset }}
 | |
|         run: |
 | |
|           make "${KATA_ASSET}-tarball"
 | |
|           build_dir=$(readlink -f build)
 | |
|           # store-artifact does not work with symlink
 | |
|           sudo cp -r "${build_dir}" "kata-build"
 | |
|         env:
 | |
|           KATA_ASSET: ${{ matrix.asset }}
 | |
|           TAR_OUTPUT: ${{ matrix.asset }}.tar.gz
 | |
|           PUSH_TO_REGISTRY: ${{ inputs.push-to-registry }}
 | |
|           ARTEFACT_REGISTRY: ghcr.io
 | |
|           ARTEFACT_REGISTRY_USERNAME: ${{ github.actor }}
 | |
|           ARTEFACT_REGISTRY_PASSWORD: ${{ secrets.GITHUB_TOKEN }}
 | |
|           TARGET_BRANCH: ${{ inputs.target-branch }}
 | |
| 
 | |
|       - name: store-artifact ${{ matrix.asset }}
 | |
|         uses: actions/upload-artifact@v3
 | |
|         with:
 | |
|           name: kata-artifacts-amd64${{ inputs.tarball-suffix }}
 | |
|           path: kata-build/kata-static-${{ matrix.asset }}.tar.xz
 | |
|           retention-days: 15
 | |
|           if-no-files-found: error
 | |
| 
 | |
|   create-kata-tarball:
 | |
|     runs-on: ubuntu-latest
 | |
|     needs: build-asset
 | |
|     steps:
 | |
|       - uses: actions/checkout@v4
 | |
|         with:
 | |
|           ref: ${{ inputs.commit-hash }}
 | |
|           fetch-depth: 0
 | |
|       - name: Rebase atop of the latest target branch
 | |
|         run: |
 | |
|           ./tests/git-helper.sh "rebase-atop-of-the-latest-target-branch"
 | |
|         env:
 | |
|           TARGET_BRANCH: ${{ inputs.target-branch }}
 | |
|       - name: get-artifacts
 | |
|         uses: actions/download-artifact@v3
 | |
|         with:
 | |
|           name: kata-artifacts-amd64${{ inputs.tarball-suffix }}
 | |
|           path: kata-artifacts
 | |
|       - name: merge-artifacts
 | |
|         run: |
 | |
|           ./tools/packaging/kata-deploy/local-build/kata-deploy-merge-builds.sh kata-artifacts versions.yaml
 | |
|       - name: store-artifacts
 | |
|         uses: actions/upload-artifact@v3
 | |
|         with:
 | |
|           name: kata-static-tarball-amd64${{ inputs.tarball-suffix }}
 | |
|           path: kata-static.tar.xz
 | |
|           retention-days: 15
 | |
|           if-no-files-found: error
 |