test buildah in actions
This commit is contained in:
		
							
								
								
									
										52
									
								
								.github/workflows/build-container.yaml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								.github/workflows/build-container.yaml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,52 @@
 | 
				
			|||||||
 | 
					---
 | 
				
			||||||
 | 
					name: "Build container"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					on:
 | 
				
			||||||
 | 
					  push:
 | 
				
			||||||
 | 
					    branches:
 | 
				
			||||||
 | 
					      - main
 | 
				
			||||||
 | 
					    tags:
 | 
				
			||||||
 | 
					      - "v*.*.*"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					jobs:
 | 
				
			||||||
 | 
					  containerization:
 | 
				
			||||||
 | 
					    runs-on: ubuntu-latest
 | 
				
			||||||
 | 
					    permissions:
 | 
				
			||||||
 | 
					      packages: write
 | 
				
			||||||
 | 
					    strategy:
 | 
				
			||||||
 | 
					      fail-fast: false
 | 
				
			||||||
 | 
					      matrix:
 | 
				
			||||||
 | 
					        include:
 | 
				
			||||||
 | 
					          - arch: amd64
 | 
				
			||||||
 | 
					          - arch: arm64
 | 
				
			||||||
 | 
					    steps:
 | 
				
			||||||
 | 
					      - name: Checkout
 | 
				
			||||||
 | 
					        uses: actions/checkout@v3
 | 
				
			||||||
 | 
					      
 | 
				
			||||||
 | 
					      - name: Install buildah
 | 
				
			||||||
 | 
					        run: sudo apt update && sudo apt install -y podman buildah qemu-user-static
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      - name: Set version tag (only if triggered by pushing a tag)
 | 
				
			||||||
 | 
					        if: startsWith(github.ref, 'refs/tags/v')
 | 
				
			||||||
 | 
					        run: echo "TAG=${GITHUB_REF##*/}" >> $GITHUB_ENV
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      - name: Set latest tag (only if triggered by pushing to the main branch)
 | 
				
			||||||
 | 
					        if: github.ref == 'main'
 | 
				
			||||||
 | 
					        run: echo "TAG=latest" >> $GITHUB_ENV
 | 
				
			||||||
 | 
					      
 | 
				
			||||||
 | 
					      - name: Set action link variable
 | 
				
			||||||
 | 
					        run: echo "LINK=$GITHUB_SERVER_URL/$GITHUB_REPOSITORY/actions/runs/$GITHUB_RUN_ID" >> $GITHUB_ENV
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      - name: Login in gchr registry
 | 
				
			||||||
 | 
					        run: buildah login --username ${{ github.repository_owner }} --password ${{ secrets.GITHUB_TOKEN }} ghcr.io
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      - name: Build an image
 | 
				
			||||||
 | 
					        run: |
 | 
				
			||||||
 | 
					          buildah bud -t ghcr.io/${{ github.repository }}:${{ github.sha }}-${{ matrix.arch }} \
 | 
				
			||||||
 | 
					            --label action_id=${{ github.action }} \
 | 
				
			||||||
 | 
					            --label action_link=${{ env.LINK }} \
 | 
				
			||||||
 | 
					            --label actor=${{ github.actor }} \
 | 
				
			||||||
 | 
					            --label sha=${{ github.sha }} \
 | 
				
			||||||
 | 
					            --label ref=${{ github.ref }} \
 | 
				
			||||||
 | 
					            .
 | 
				
			||||||
							
								
								
									
										52
									
								
								.github/workflows/container-latest.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										52
									
								
								.github/workflows/container-latest.yaml
									
									
									
									
										vendored
									
									
								
							@@ -1,52 +0,0 @@
 | 
				
			|||||||
---
 | 
					 | 
				
			||||||
name: "Latest container"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
on:
 | 
					 | 
				
			||||||
  push:
 | 
					 | 
				
			||||||
    branches:
 | 
					 | 
				
			||||||
      - main
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
jobs:
 | 
					 | 
				
			||||||
  containerization:
 | 
					 | 
				
			||||||
    runs-on: ubuntu-latest
 | 
					 | 
				
			||||||
    permissions:
 | 
					 | 
				
			||||||
      packages: write
 | 
					 | 
				
			||||||
    steps:
 | 
					 | 
				
			||||||
      - name: Checkout
 | 
					 | 
				
			||||||
        uses: actions/checkout@v3
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Set action link variable
 | 
					 | 
				
			||||||
        run: echo "LINK=$GITHUB_SERVER_URL/$GITHUB_REPOSITORY/actions/runs/$GITHUB_RUN_ID" >> $GITHUB_ENV
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Set up QEMU
 | 
					 | 
				
			||||||
        uses: docker/setup-qemu-action@master
 | 
					 | 
				
			||||||
        with:
 | 
					 | 
				
			||||||
          platforms: all
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Set up Docker Buildx
 | 
					 | 
				
			||||||
        id: buildx
 | 
					 | 
				
			||||||
        uses: docker/setup-buildx-action@master
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Login to GitHub Container Registry
 | 
					 | 
				
			||||||
        uses: docker/login-action@v2
 | 
					 | 
				
			||||||
        with:
 | 
					 | 
				
			||||||
          registry: ghcr.io
 | 
					 | 
				
			||||||
          username: ${{ github.repository_owner }}
 | 
					 | 
				
			||||||
          password: ${{ secrets.GITHUB_TOKEN }}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Build
 | 
					 | 
				
			||||||
        uses: docker/build-push-action@v3
 | 
					 | 
				
			||||||
        with:
 | 
					 | 
				
			||||||
          builder: ${{ steps.buildx.outputs.name }}
 | 
					 | 
				
			||||||
          context: .
 | 
					 | 
				
			||||||
          file: ./Dockerfile
 | 
					 | 
				
			||||||
          platforms: linux/amd64,linux/arm64
 | 
					 | 
				
			||||||
          push: true
 | 
					 | 
				
			||||||
          tags: |
 | 
					 | 
				
			||||||
            ghcr.io/${{ github.repository }}:latest
 | 
					 | 
				
			||||||
          labels: |
 | 
					 | 
				
			||||||
            action_id=${{ github.action }}
 | 
					 | 
				
			||||||
            action_link=${{ env.LINK }}
 | 
					 | 
				
			||||||
            actor=${{ github.actor }}
 | 
					 | 
				
			||||||
            sha=${{ github.sha }}
 | 
					 | 
				
			||||||
            ref=${{ github.ref }}
 | 
					 | 
				
			||||||
@@ -1,4 +1,4 @@
 | 
				
			|||||||
FROM rust:1.70.0-slim-bookworm as builder
 | 
					FROM registry.hub.docker.com/library/rust:1.70.0-slim-bookworm as builder
 | 
				
			||||||
WORKDIR /src
 | 
					WORKDIR /src
 | 
				
			||||||
RUN apt-get update &&\
 | 
					RUN apt-get update &&\
 | 
				
			||||||
		apt-get install -y libssl-dev gcc musl pkg-config
 | 
							apt-get install -y libssl-dev gcc musl pkg-config
 | 
				
			||||||
@@ -9,9 +9,9 @@ RUN cargo build --release --jobs 2 -Z sparse-registry
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
FROM debian:stable
 | 
					FROM debian:stable
 | 
				
			||||||
COPY --from=builder /src/target/release/dudo /bin/dudo
 | 
					COPY --from=builder /src/target/release/dudo /bin/dudo
 | 
				
			||||||
RUN apt-get update &&\
 | 
					RUN apt-get update -y &&\
 | 
				
			||||||
		apt-get install openssl ca-certificates &&\
 | 
							apt-get install openssl ca-certificates -y &&\
 | 
				
			||||||
		apt-get clean
 | 
							apt-get clean -y
 | 
				
			||||||
RUN chmod +x /bin/dudo
 | 
					RUN chmod +x /bin/dudo
 | 
				
			||||||
WORKDIR /workdir
 | 
					WORKDIR /workdir
 | 
				
			||||||
ENTRYPOINT ["/bin/dudo"]
 | 
					ENTRYPOINT ["/bin/dudo"]
 | 
				
			||||||
		Reference in New Issue
	
	Block a user