mirror of
https://github.com/redhat-actions/push-to-registry.git
synced 2025-02-22 18:21:20 +01:00
Document and add GHCR example (#49)
* Document and add GHCR example Signed-off-by: divyansh42 <diagrawa@redhat.com>
This commit is contained in:
parent
227b0eed37
commit
1d3fd04cee
3 changed files with 76 additions and 8 deletions
65
.github/workflows/ghcr-push.yaml
vendored
Normal file
65
.github/workflows/ghcr-push.yaml
vendored
Normal file
|
@ -0,0 +1,65 @@
|
||||||
|
# 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: Push to GHCR
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
workflow_dispatch:
|
||||||
|
schedule:
|
||||||
|
- cron: '0 0 * * *' # every day at midnight
|
||||||
|
env:
|
||||||
|
IMAGE_NAME: ptr-test
|
||||||
|
IMAGE_TAGS: v1 ${{ github.sha }}
|
||||||
|
IMAGE_REGISTRY: ghcr.io/${{ github.repository_owner }}
|
||||||
|
REGISTRY_USER: ${{ github.actor }}
|
||||||
|
REGISTRY_PASSWORD: ${{ github.token }}
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
push-ghcr:
|
||||||
|
name: Build and push image
|
||||||
|
runs-on: ubuntu-20.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@v2
|
||||||
|
|
||||||
|
- name: Install latest podman
|
||||||
|
if: matrix.install_latest
|
||||||
|
run: |
|
||||||
|
bash .github/install_latest_podman.sh
|
||||||
|
|
||||||
|
# Build image using Buildah action
|
||||||
|
- name: Build Image
|
||||||
|
id: build_image
|
||||||
|
uses: redhat-actions/buildah-build@v2
|
||||||
|
with:
|
||||||
|
image: ${{ env.IMAGE_NAME }}
|
||||||
|
tags: ${{ env.IMAGE_TAGS }}
|
||||||
|
base-image: busybox:latest
|
||||||
|
entrypoint: |
|
||||||
|
bash
|
||||||
|
-c
|
||||||
|
echo 'hello world'
|
||||||
|
oci: true
|
||||||
|
|
||||||
|
# Push the image to GHCR (Image Registry)
|
||||||
|
- name: Push To GHCR
|
||||||
|
uses: ./
|
||||||
|
id: push
|
||||||
|
with:
|
||||||
|
image: ${{ steps.build_image.outputs.image }}
|
||||||
|
tags: ${{ steps.build_image.outputs.tags }}
|
||||||
|
registry: ${{ env.IMAGE_REGISTRY }}
|
||||||
|
username: ${{ env.REGISTRY_USER }}
|
||||||
|
password: ${{ env.REGISTRY_PASSWORD }}
|
||||||
|
extra-args: |
|
||||||
|
--disable-content-trust
|
||||||
|
|
||||||
|
- name: Echo outputs
|
||||||
|
run: |
|
||||||
|
echo "${{ toJSON(steps.push.outputs) }}"
|
|
@ -1,7 +1,7 @@
|
||||||
# This workflow will perform a test whenever there
|
# This workflow will perform a test whenever there
|
||||||
# is some change in code done to ensure that the changes
|
# is some change in code done to ensure that the changes
|
||||||
# are not buggy and we are getting the desired output.
|
# are not buggy and we are getting the desired output.
|
||||||
name: Build and Push
|
name: Push to Quay.io
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
@ -9,15 +9,14 @@ on:
|
||||||
- cron: '0 0 * * *' # every day at midnight
|
- cron: '0 0 * * *' # every day at midnight
|
||||||
|
|
||||||
env:
|
env:
|
||||||
IMAGE_REGISTRY: quay.io
|
|
||||||
IMAGE_NAMESPACE: redhat-github-actions
|
|
||||||
IMAGE_NAME: ptr-test
|
IMAGE_NAME: ptr-test
|
||||||
IMAGE_TAGS: v1 ${{ github.sha }}
|
IMAGE_TAGS: v1 ${{ github.sha }}
|
||||||
MVN_REPO_DIR: ~/.m2/repository
|
IMAGE_REGISTRY: quay.io
|
||||||
|
IMAGE_NAMESPACE: redhat-github-actions
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build-and-push:
|
push-quay:
|
||||||
name: Build and push image to Quay.io
|
name: Build and push image
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
|
@ -1,10 +1,12 @@
|
||||||
# push-to-registry
|
# push-to-registry
|
||||||
|
|
||||||
[](https://github.com/redhat-actions/push-to-registry/actions?query=workflow%3A%22CI+checks%22)
|
[](https://github.com/redhat-actions/push-to-registry/actions?query=workflow%3A%22CI+checks%22)
|
||||||
[](https://github.com/redhat-actions/push-to-registry/actions?query=workflow%3A%22Build+and+Push%22)
|
[](https://github.com/redhat-actions/push-to-registry/actions?query=workflow%3A%22Link+checker%22)
|
||||||
|
<br><br>
|
||||||
|
[](https://github.com/redhat-actions/push-to-registry/actions/workflows/quay-push.yaml)
|
||||||
|
[](https://github.com/redhat-actions/push-to-registry/actions/workflows/ghcr-push.yaml)
|
||||||
[](https://github.com/redhat-actions/push-to-registry/actions?query=workflow%3A%22Login+and+Push%22)
|
[](https://github.com/redhat-actions/push-to-registry/actions?query=workflow%3A%22Login+and+Push%22)
|
||||||
[](https://github.com/redhat-actions/push-to-registry/actions?query=workflow%3A%22Multiple+container+CLI+build+tests%22)
|
[](https://github.com/redhat-actions/push-to-registry/actions?query=workflow%3A%22Multiple+container+CLI+build+tests%22)
|
||||||
[](https://github.com/redhat-actions/push-to-registry/actions?query=workflow%3A%22Link+checker%22)
|
|
||||||
<br><br>
|
<br><br>
|
||||||
[](https://github.com/redhat-actions/push-to-registry/tags)
|
[](https://github.com/redhat-actions/push-to-registry/tags)
|
||||||
[](./LICENSE)
|
[](./LICENSE)
|
||||||
|
@ -94,6 +96,8 @@ jobs:
|
||||||
run: echo "Image pushed to ${{ steps.push-to-quay.outputs.registry-paths }}"
|
run: echo "Image pushed to ${{ steps.push-to-quay.outputs.registry-paths }}"
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Refer to [GHCR push example](./.github/workflows/ghcr-push.yaml) for complete example of push to [GitHub Container Registry (GHCR)](https://docs.github.com/en/packages/working-with-a-github-packages-registry/working-with-the-container-registry).
|
||||||
|
|
||||||
## Note about images built with Docker
|
## Note about images built with Docker
|
||||||
|
|
||||||
This action uses `Podman` to push, but can also push images built with `Docker`. However, Docker and Podman store their images in different locations, and Podman can only push images in its own storage.
|
This action uses `Podman` to push, but can also push images built with `Docker`. However, Docker and Podman store their images in different locations, and Podman can only push images in its own storage.
|
||||||
|
|
Loading…
Add table
Reference in a new issue