ci: new workflow to build and deploy the app
This commit is contained in:
parent
d454ec8fc9
commit
f9f22cd7f4
2 changed files with 137 additions and 59 deletions
137
.github/workflows/deploy-to-staging.yml
vendored
Normal file
137
.github/workflows/deploy-to-staging.yml
vendored
Normal file
|
|
@ -0,0 +1,137 @@
|
|||
name: Deploy to staging from main branch
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
tags-ignore:
|
||||
- '*' # ignore all tags
|
||||
|
||||
concurrency:
|
||||
group: deploy-staging
|
||||
cancel-in-progress: true
|
||||
|
||||
env:
|
||||
NAMESPACE: backoffice-staging
|
||||
HELM_VERSION: "3.12.1"
|
||||
DOCKER_REGISTRY: ghcr.io
|
||||
DOCKER_IMAGE: vojtechmares/backoffice
|
||||
|
||||
jobs:
|
||||
build:
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
with:
|
||||
ref: ${{ github.ref }}
|
||||
|
||||
- name: set up qemu
|
||||
uses: docker/setup-qemu-action@v2
|
||||
|
||||
- name: set up docker buildx
|
||||
uses: docker/setup-buildx-action@v2
|
||||
|
||||
- name: docker login
|
||||
uses: docker/login-action@v2
|
||||
with:
|
||||
registry: ${{ env.DOCKER_REGISTRY }}
|
||||
username: ${{ github.actor }}
|
||||
password: ${{ secrets.GITHUB_TOKEN }}
|
||||
|
||||
- name: docker meta
|
||||
id: docker_meta
|
||||
uses: docker/metadata-action@v4
|
||||
with:
|
||||
tags: |
|
||||
type=schedule
|
||||
type=ref,event=branch
|
||||
type=ref,event=tag
|
||||
type=ref,event=pr
|
||||
type=sha,format=long
|
||||
type=raw,value=${{ github.ref_name }}-${{ github.sha }}
|
||||
type=raw,value=latest,enable=${{ github.ref == format('refs/heads/{0}', 'main') }}
|
||||
images: |
|
||||
${{ env.DOCKER_REGISTRY }}/${{ env.DOCKER_IMAGE }}
|
||||
|
||||
- name: build and push
|
||||
uses: docker/build-push-action@v4
|
||||
with:
|
||||
pull: true
|
||||
push: true
|
||||
tags: ${{ steps.docker_meta.outputs.tags }}
|
||||
labels: ${{ steps.docker_meta.outputs.labels }}
|
||||
# platforms: linux/amd64,linux/arm64,linux/arm/v7
|
||||
cache-from: type=registry,ref=${{ env.DOCKER_REGISTRY }}/${{ env.DOCKER_IMAGE }}:latest
|
||||
|
||||
deploy:
|
||||
runs-on: ubuntu-latest
|
||||
environment:
|
||||
name: staging
|
||||
url: https://staging.backoffice.mareshq.com
|
||||
needs:
|
||||
- build
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
with:
|
||||
ref: ${{ github.ref }}
|
||||
|
||||
# Setup kubectl and Helm for Azure
|
||||
- uses: azure/setup-helm@v3
|
||||
with:
|
||||
version: "${{ env.HELM_VERSION }}"
|
||||
|
||||
- uses: azure/k8s-set-context@v3
|
||||
with:
|
||||
method: kubeconfig
|
||||
kubeconfig: ${{ secrets.KUBECONFIG_CONTENT }}
|
||||
context: kiwi
|
||||
|
||||
# - name: set imagepullsecret
|
||||
# uses: azure/k8s-create-secret@v4
|
||||
# with:
|
||||
# namespace: ${{ env.NAMESPACE }}}
|
||||
# secret-name: ghcr-io-pull-secret
|
||||
# container-registry-url: ${{ env.DOCKER_REGISTRY }}
|
||||
# container-registry-username: ${{ secrets.REGISTRY_USERNAME }}
|
||||
# container-registry-password: ${{ secrets.REGISTRY_PASSWORD }}
|
||||
# id: create-secret
|
||||
|
||||
- name: deploy dry run
|
||||
run: |
|
||||
helm upgrade \
|
||||
--atomic \
|
||||
--wait=true \
|
||||
--wait-for-jobs=true \
|
||||
--timeout 900s \
|
||||
--dry-run=true \
|
||||
--install \
|
||||
--namespace=${{ env.NAMESPACE }} \
|
||||
-f ./charts/backoffice/values.staging.yaml \
|
||||
--set image.tag=${{ github.ref_name }}-${{ github.sha }} \
|
||||
--set secrets.databaseURL=dummy \
|
||||
--set secrets.nextauthSecret=dummy \
|
||||
--set secrets.googleClientID=dummy \
|
||||
--set secrets.googleClientSecret=dummy \
|
||||
backoffice \
|
||||
./charts/backoffice
|
||||
|
||||
- name: deploy
|
||||
run: |
|
||||
helm upgrade \
|
||||
--atomic \
|
||||
--wait=true \
|
||||
--wait-for-jobs=true \
|
||||
--timeout 900s \
|
||||
--dry-run=true \
|
||||
--install \
|
||||
--namespace=${{ env.NAMESPACE }} \
|
||||
-f ./charts/backoffice/values.staging.yaml \
|
||||
--set image.tag=${{ github.ref_name }}-${{ github.sha }} \
|
||||
--set secrets.databaseURL=${{ secrets.DATABASE_URL }} \
|
||||
--set secrets.nextauthSecret=${{ secrets.NEXTAUTH_SECRET }} \
|
||||
--set secrets.googleClientID=${{ secrets.GOOGLE_CLIENT_ID }} \
|
||||
--set secrets.googleClientSecret=${{ secrets.GOOGLE_CLIENT_SECRET }} \
|
||||
backoffice \
|
||||
./charts/backoffice
|
||||
59
.github/workflows/docker.yml
vendored
59
.github/workflows/docker.yml
vendored
|
|
@ -1,59 +0,0 @@
|
|||
name: Docker build on main branch
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
|
||||
env:
|
||||
DOCKER_REGISTRY: ghcr.io
|
||||
DOCKER_IMAGE: vojtechmares/backoffice
|
||||
|
||||
jobs:
|
||||
build:
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
with:
|
||||
ref: ${{ github.ref }}
|
||||
|
||||
# Setup Docker
|
||||
- name: Set up QEMU
|
||||
uses: docker/setup-qemu-action@v2
|
||||
|
||||
- name: Set up Docker Buildx
|
||||
uses: docker/setup-buildx-action@v2
|
||||
|
||||
- name: Docker login
|
||||
uses: docker/login-action@v2
|
||||
with:
|
||||
registry: ${{ env.DOCKER_REGISTRY }}
|
||||
# Use repository secrets for username and password, not organization secrets
|
||||
username: ${{ github.actor }}
|
||||
password: ${{ secrets.GITHUB_TOKEN }}
|
||||
|
||||
- name: Docker meta
|
||||
id: docker_meta
|
||||
uses: docker/metadata-action@v4
|
||||
with:
|
||||
tags: |
|
||||
type=schedule
|
||||
type=ref,event=branch
|
||||
type=ref,event=tag
|
||||
type=ref,event=pr
|
||||
type=sha,format=long
|
||||
type=raw,value=${{ github.ref_name }}-${{ github.sha }}
|
||||
type=raw,value=latest,enable=${{ github.ref == format('refs/heads/{0}', 'main') }}
|
||||
images: |
|
||||
${{ env.DOCKER_REGISTRY }}/${{ env.DOCKER_IMAGE }}
|
||||
|
||||
- name: Build and push
|
||||
uses: docker/build-push-action@v4
|
||||
with:
|
||||
pull: true
|
||||
push: true
|
||||
tags: ${{ steps.docker_meta.outputs.tags }}
|
||||
labels: ${{ steps.docker_meta.outputs.labels }}
|
||||
# platforms: linux/amd64,linux/arm64,linux/arm/v7
|
||||
cache-from: type=registry,ref=${{ env.DOCKER_REGISTRY }}/${{ env.DOCKER_IMAGE }}:latest
|
||||
Reference in a new issue