Login and Push #1296
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# This workflow will perform a test whenever there | |
# is some change in code done to ensure that the changes | |
# are not buggy and we are getting the desired output. | |
name: Login and Push | |
on: | |
push: | |
workflow_dispatch: | |
schedule: | |
- cron: '0 0 * * *' # every day at midnight | |
env: | |
IMAGE_REGISTRY: quay.io | |
IMAGE_NAMESPACE: redhat-github-actions | |
IMAGE_NAME: ptr-test | |
IMAGE_TAGS: v1 ${{ github.sha }} | |
jobs: | |
login-and-push: | |
name: Login and push image to Quay.io | |
runs-on: ubuntu-22.04 | |
strategy: | |
fail-fast: false | |
matrix: | |
install_latest: [ true, false ] | |
steps: | |
# Checkout push-to-registry action github repository | |
- name: Checkout Push to Registry action | |
uses: actions/checkout@v4 | |
- name: Install latest podman | |
if: matrix.install_latest | |
run: | | |
bash .github/install_latest_podman.sh | |
- name: Create Dockerfile | |
run: | | |
cat > Dockerfile<<EOF | |
FROM busybox | |
RUN echo "hello world" | |
EOF | |
# Build image using Buildah action | |
- name: Build Image | |
id: build_image | |
uses: redhat-actions/buildah-build@v2 | |
with: | |
image: ${{ env.IMAGE_NAME }} | |
layers: false | |
tags: ${{ env.IMAGE_TAGS }} | |
dockerfiles: | | |
./Dockerfile | |
# Authenticate to container image registry to push the image | |
- name: Podman Login | |
uses: redhat-actions/podman-login@v1 | |
with: | |
registry: quay.io | |
username: ${{ secrets.REGISTRY_USER }} | |
password: ${{ secrets.REGISTRY_PASSWORD }} | |
# Push the image to Quay.io (Image Registry) | |
- name: Push To Quay | |
uses: ./ | |
id: push | |
with: | |
image: ${{ steps.build_image.outputs.image }} | |
tags: ${{ steps.build_image.outputs.tags }} | |
registry: ${{ env.IMAGE_REGISTRY }}/${{ env.IMAGE_NAMESPACE }} | |
extra-args: | | |
--disable-content-trust | |
- name: Echo outputs | |
run: | | |
echo "${{ toJSON(steps.push.outputs) }}" |