mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-01-12 18:44:14 +00:00
1d668d7deb
Bumps [docker/build-push-action](https://github.com/docker/build-push-action) from 5.3.0 to 5.4.0. - [Release notes](https://github.com/docker/build-push-action/releases) - [Commits](https://github.com/docker/build-push-action/compare/v5.3.0...v5.4.0) --- updated-dependencies: - dependency-name: docker/build-push-action dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Kevin Burnett <18027+burnettk@users.noreply.github.com>
239 lines
9.7 KiB
YAML
239 lines
9.7 KiB
YAML
name: Build Docker Images
|
|
# we want to be able to sort by tag name to find the newest and trace back to source control
|
|
# on every commit to main:
|
|
# frontend:main-20230223164322-b8becd1-45
|
|
# frontend:main-latest
|
|
# we settled on:
|
|
# main-2023-02-24_16-16-40
|
|
# because the labels on the docker image itself have the git sha and everything else :)
|
|
# on every tag:
|
|
# frontend:latest
|
|
#
|
|
# Example docker image labels:
|
|
# "Labels": {
|
|
# "description": "Software development platform for building, running, and monitoring executable diagrams",
|
|
# "org.opencontainers.image.created": "2023-02-24T16:43:00.844Z",
|
|
# "org.opencontainers.image.description": "",
|
|
# "org.opencontainers.image.licenses": "LGPL-2.1",
|
|
# "org.opencontainers.image.revision": "54064a050fbf9f366648f0f2e2c60ce244fcc421",
|
|
# "org.opencontainers.image.source": "https://github.com/sartography/spiff-arena",
|
|
# "org.opencontainers.image.title": "spiff-arena",
|
|
# "org.opencontainers.image.url": "https://github.com/sartography/spiff-arena",
|
|
# "org.opencontainers.image.version": "main-latest",
|
|
# "source": "https://github.com/sartography/spiff-arena"
|
|
# }
|
|
#
|
|
# Git tags for an image:
|
|
# curl -H "Authorization: Bearer $(echo -n $TOKEN | base64 -w0)" https://ghcr.io/v2/sartography/spiffworkflow-backend/tags/list | jq -r '.tags | sort_by(.)'
|
|
|
|
on:
|
|
push:
|
|
branches:
|
|
- main
|
|
tags: [v*]
|
|
|
|
jobs:
|
|
create_frontend_docker_image:
|
|
runs-on: ubuntu-latest
|
|
env:
|
|
REGISTRY: ghcr.io
|
|
IMAGE_NAME: sartography/spiffworkflow-frontend
|
|
BRANCH_NAME: ${{ github.head_ref || github.ref_name }}
|
|
permissions:
|
|
contents: read
|
|
packages: write
|
|
steps:
|
|
- name: Check out the repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Docker Buildx
|
|
uses: docker/setup-buildx-action@v3
|
|
- name: Log in to the Container registry
|
|
uses: docker/login-action@v3.2.0
|
|
with:
|
|
registry: ${{ env.REGISTRY }}
|
|
username: ${{ github.actor }}
|
|
password: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
- name: Get current date
|
|
id: date
|
|
run: echo "date=$(date -u +'%Y-%m-%d_%H-%M-%S')" >> "$GITHUB_OUTPUT"
|
|
- name: Get short commit sha
|
|
id: commit_sha
|
|
run: echo "sha_short=$(git rev-parse --short HEAD)" >> "$GITHUB_OUTPUT"
|
|
- name: Extract metadata (tags, labels) for Docker
|
|
id: meta
|
|
uses: docker/metadata-action@v5.5.1
|
|
with:
|
|
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
|
|
labels: |
|
|
org.opencontainers.image.description=Frontend component of SpiffWorkflow, a software development platform for building, running, and monitoring executable diagrams
|
|
org.opencontainers.image.version=${{ env.BRANCH_NAME }}-${{ steps.date.outputs.date }}-${{ steps.commit_sha.outputs.sha_short }}
|
|
tags: |
|
|
type=ref,event=branch,branch=main,suffix=-latest
|
|
type=ref,event=branch,suffix=-${{ steps.date.outputs.date }}-${{ steps.commit_sha.outputs.sha_short }}
|
|
type=ref,event=tag,enable=true,format={{version}}
|
|
type=ref,event=tag,enable=true,format=latest
|
|
|
|
- name: Write app version info
|
|
working-directory: spiffworkflow-frontend
|
|
run: echo "$DOCKER_METADATA_OUTPUT_JSON" | jq '.labels' > version_info.json
|
|
- name: Build and push Frontend Docker image
|
|
uses: docker/build-push-action@v5.4.0
|
|
with:
|
|
# this action doesn't seem to respect working-directory so set context
|
|
context: spiffworkflow-frontend
|
|
push: true
|
|
tags: ${{ steps.meta.outputs.tags }}
|
|
labels: ${{ steps.meta.outputs.labels }}
|
|
platforms: linux/amd64,linux/arm64
|
|
- run: echo 'TAGS' >> "$GITHUB_STEP_SUMMARY"
|
|
- run: echo 'TAGS ${{ steps.meta.outputs.tags }}' >> "$GITHUB_STEP_SUMMARY"
|
|
|
|
create_backend_docker_image:
|
|
runs-on: ubuntu-latest
|
|
env:
|
|
REGISTRY: ghcr.io
|
|
IMAGE_NAME: sartography/spiffworkflow-backend
|
|
BRANCH_NAME: ${{ github.head_ref || github.ref_name }}
|
|
permissions:
|
|
contents: read
|
|
packages: write
|
|
steps:
|
|
- name: Check out the repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Docker Buildx
|
|
uses: docker/setup-buildx-action@v3
|
|
- name: Log in to the Container registry
|
|
uses: docker/login-action@v3.2.0
|
|
with:
|
|
registry: ${{ env.REGISTRY }}
|
|
username: ${{ github.actor }}
|
|
password: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
- name: Get current date
|
|
id: date
|
|
run: echo "date=$(date -u +'%Y-%m-%d_%H-%M-%S')" >> "$GITHUB_OUTPUT"
|
|
- name: Get short commit sha
|
|
id: commit_sha
|
|
run: echo "sha_short=$(git rev-parse --short HEAD)" >> "$GITHUB_OUTPUT"
|
|
- name: Extract metadata (tags, labels) for Docker
|
|
id: meta
|
|
uses: docker/metadata-action@v5.5.1
|
|
with:
|
|
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
|
|
labels: |
|
|
org.opencontainers.image.description=Backend component of SpiffWorkflow, a software development platform for building, running, and monitoring executable diagrams
|
|
org.opencontainers.image.version=${{ env.BRANCH_NAME }}-${{ steps.date.outputs.date }}-${{ steps.commit_sha.outputs.sha_short }}
|
|
tags: |
|
|
type=ref,event=branch,branch=main,suffix=-latest
|
|
type=ref,event=branch,suffix=-${{ steps.date.outputs.date }}-${{ steps.commit_sha.outputs.sha_short }}
|
|
type=ref,event=tag,enable=true,format={{version}}
|
|
type=ref,event=tag,enable=true,format=latest
|
|
|
|
- name: Write app version info
|
|
working-directory: spiffworkflow-backend
|
|
run: echo "$DOCKER_METADATA_OUTPUT_JSON" | jq '.labels' > version_info.json
|
|
- name: Build and push Backend Docker image
|
|
uses: docker/build-push-action@v5.4.0
|
|
with:
|
|
# this action doesn't seem to respect working-directory so set context
|
|
context: spiffworkflow-backend
|
|
push: true
|
|
tags: ${{ steps.meta.outputs.tags }}
|
|
labels: ${{ steps.meta.outputs.labels }}
|
|
platforms: linux/amd64,linux/arm64
|
|
- name: Adding markdown
|
|
run: echo 'TAGS ${{ steps.meta.outputs.tags }}' >> "$GITHUB_STEP_SUMMARY"
|
|
|
|
create_demo_proxy_docker_image:
|
|
runs-on: ubuntu-latest
|
|
env:
|
|
REGISTRY: ghcr.io
|
|
IMAGE_NAME: sartography/connector-proxy-demo
|
|
BRANCH_NAME: ${{ github.head_ref || github.ref_name }}
|
|
|
|
permissions:
|
|
contents: read
|
|
packages: write
|
|
steps:
|
|
- name: Check out the repository
|
|
uses: actions/checkout@v4
|
|
- name: Set up Docker Buildx
|
|
uses: docker/setup-buildx-action@v3
|
|
- name: Log in to the Container registry
|
|
uses: docker/login-action@v3.2.0
|
|
with:
|
|
registry: ${{ env.REGISTRY }}
|
|
username: ${{ github.actor }}
|
|
password: ${{ secrets.GITHUB_TOKEN }}
|
|
|
|
- name: Get current date
|
|
id: date
|
|
run: echo "date=$(date -u +'%Y-%m-%d_%H-%M-%S')" >> "$GITHUB_OUTPUT"
|
|
- name: Get short commit sha
|
|
id: commit_sha
|
|
run: echo "sha_short=$(git rev-parse --short HEAD)" >> "$GITHUB_OUTPUT"
|
|
- name: Extract metadata (tags, labels) for Docker
|
|
id: meta
|
|
uses: docker/metadata-action@v5.5.1
|
|
with:
|
|
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
|
|
labels: |
|
|
org.opencontainers.image.description=spiffworkflow-connector-proxy-demo
|
|
org.opencontainers.image.version=${{ env.BRANCH_NAME }}-${{ steps.date.outputs.date }}-${{ steps.commit_sha.outputs.sha_short }}
|
|
tags: |
|
|
type=ref,event=branch,branch=main,suffix=-latest
|
|
type=ref,event=branch,suffix=-${{ steps.date.outputs.date }}-${{ steps.commit_sha.outputs.sha_short }}
|
|
type=ref,event=tag,enable=true,format={{version}}
|
|
type=ref,event=tag,enable=true,format=latest
|
|
|
|
- name: Build and push the connector proxy
|
|
uses: docker/build-push-action@v5.4.0
|
|
with:
|
|
# this action doesn't seem to respect working-directory so set context
|
|
context: connector-proxy-demo
|
|
push: true
|
|
tags: ${{ steps.meta.outputs.tags }}
|
|
labels: ${{ steps.meta.outputs.labels }}
|
|
platforms: linux/amd64,linux/arm64
|
|
- name: Adding markdown
|
|
run: echo 'TAGS ${{ steps.meta.outputs.tags }}' >> "$GITHUB_STEP_SUMMARY"
|
|
|
|
quickstart-guide-test:
|
|
runs-on: ubuntu-latest
|
|
if: startsWith(github.ref, 'refs/tags/v')
|
|
needs:
|
|
[
|
|
create_frontend_docker_image,
|
|
create_backend_docker_image,
|
|
create_demo_proxy_docker_image,
|
|
]
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v4
|
|
- name: Setup Apps
|
|
run: ./bin/run_arena_with_docker_compose
|
|
- name: wait_for_backend
|
|
working-directory: ./spiffworkflow-backend
|
|
run: ./bin/wait_for_backend_to_be_up 5 8000
|
|
- name: wait_for_frontend
|
|
working-directory: ./spiffworkflow-frontend
|
|
run: ./bin/wait_for_frontend_to_be_up 5 8001
|
|
- name: wait_for_connector
|
|
working-directory: ./connector-proxy-demo
|
|
run: ./bin/wait_for_connector_to_be_up 5 8004
|
|
- name: Cypress run
|
|
uses: cypress-io/github-action@v6
|
|
with:
|
|
working-directory: ./spiffworkflow-frontend
|
|
browser: chromium
|
|
# just run one test to make sure we didn't completely break it
|
|
spec: cypress/e2e/process_groups.cy.js
|
|
env:
|
|
# pass GitHub token to allow accurately detecting a build vs a re-run build
|
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
CYPRESS_SPIFFWORKFLOW_FRONTEND_AUTH_WITH_KEYCLOAK: "false"
|
|
CYPRESS_SPIFFWORKFLOW_FRONTEND_USERNAME: "admin"
|
|
CYPRESS_SPIFFWORKFLOW_FRONTEND_PASSWORD: "admin"
|
|
SPIFFWORKFLOW_FRONTEND_PORT: 8001
|