Test PR Restrictions #24

Closed
chris wants to merge 2 commits from testing into release
2 changed files with 78 additions and 37 deletions

View File

@ -6,56 +6,24 @@ on:
- release
jobs:
Cleanup-Old-Artifacts:
Checkout-Branch:
runs-on: self-hosted
defaults:
run:
working-directory: /home/builds/src
working-directory: /home/builds/src/ansible-dev
steps:
- name: Cleanup old code
run: rm -rfv *
Check-Environment:
runs-on: self-hosted
needs: [Cleanup-Old-Artifacts]
defaults:
run:
working-directory: /home/builds/src
steps:
- name: Environment check
- name: Checkout release branch
run: |
echo "BUILD_USER: $(whoami)" && echo
echo "PWD: $(pwd)" && echo
hostnamectl && echo
lscpu && echo
env && echo
docker info && echo
Clone-Repo:
runs-on: self-hosted
needs: [Check-Environment]
defaults:
run:
working-directory: /home/builds/src
steps:
- name: Clone repository
run: |
git clone https://gitea.thezengarden.net/podman/ansible-dev.git
cd ansible-dev
git checkout ${{ env.GITHUB_REF_NAME }}
- name: Verify current commit
run: cd ansible-dev && git log -1
run: git log -1
Build-Images:
runs-on: self-hosted
needs: [Check-Environment]
needs: [Checkout-Branch]
defaults:
run:
working-directory: /home/builds/src/ansible-dev

View File

@ -0,0 +1,73 @@
name: Docker Image Build Pipeline
on:
push:
branches:
- staging
jobs:
Checkout-Branch:
runs-on: self-hosted
defaults:
run:
working-directory: /home/builds/src/ansible-dev
steps:
- name: Checkout staging branch
run: |
git checkout ${{ env.GITHUB_REF_NAME }}
- name: Verify current commit
run: git log -1
Build-Images:
runs-on: self-hosted
needs: [Checkout-Branch]
defaults:
run:
working-directory: /home/builds/src/ansible-dev
steps:
- name: Fedora
run: |
echo "docker build -f build/Containerfile.fedora -t ${{ vars.REGISTRY }}/${{ env.GITHUB_REPOSITORY }}/${{ vars.BUILD_NAME_FEDORA }}:${{ env.GITHUB_REF_NAME }} ."
docker build -f build/Containerfile.fedora -t ${{ vars.REGISTRY }}/${{ env.GITHUB_REPOSITORY }}/${{ vars.BUILD_NAME_FEDORA }}:${{ env.GITHUB_REF_NAME }} .
- name: Debian
run: |
echo "docker build -f build/Containerfile.debian -t ${{ vars.REGISTRY }}/${{ env.GITHUB_REPOSITORY }}/${{ vars.BUILD_NAME_DEBIAN }}:${{ env.GITHUB_REF_NAME }} ."
docker build -f build/Containerfile.debian -t ${{ vars.REGISTRY }}/${{ env.GITHUB_REPOSITORY }}/${{ vars.BUILD_NAME_DEBIAN }}:${{ env.GITHUB_REF_NAME }} .
Push-Images:
runs-on: self-hosted
needs: [Build-Images]
steps:
- name: Docker login
run: echo "${{ secrets.REGISTRY_PASSWORD }}" | docker login --username ${{ secrets.REGISTRY_USER }} --password-stdin ${{ vars.REGISTRY }}
- name: Push images to registry
run: |
pwd
docker push ${{ vars.REGISTRY }}/${{ env.GITHUB_REPOSITORY }}/${{ vars.BUILD_NAME_FEDORA }}:${{ env.GITHUB_REF_NAME }}
docker push ${{ vars.REGISTRY }}/${{ env.GITHUB_REPOSITORY }}/${{ vars.BUILD_NAME_DEBIAN }}:${{ env.GITHUB_REF_NAME }}
Cleanup-Build-Images:
runs-on: self-hosted
needs: [Build-Images, Push-Images]
steps:
- name: Cleanup build images
run: |
pwd
docker rmi ${{ vars.REGISTRY }}/${{ env.GITHUB_REPOSITORY }}/${{ vars.BUILD_NAME_FEDORA }}:${{ env.GITHUB_REF_NAME }}
docker rmi ${{ vars.REGISTRY }}/${{ env.GITHUB_REPOSITORY }}/${{ vars.BUILD_NAME_DEBIAN }}:${{ env.GITHUB_REF_NAME }}
Cleanup-Docker-Login:
runs-on: self-hosted
needs: [Push-Images]
steps:
- name: Cleanup Docker login
run: rm -v /home/builds/.docker/config.json