December gas and gss update #3
Workflow file for this run
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
name: Тесты и раскатка в продакшн | |
on: | |
push: | |
tags: | |
- 'v*' | |
env: | |
REGISTRY: ghcr.io | |
IMAGE_NAME: ${{ github.repository }} | |
jobs: | |
build-preprod-image: | |
name: Собираем pre-prod Docker | |
runs-on: ubuntu-latest | |
permissions: | |
contents: read | |
packages: write | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Log in to the Container registry | |
uses: docker/login-action@v2 | |
with: | |
registry: ${{ env.REGISTRY }} | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Define preprod metadata | |
id: meta-preprod | |
uses: docker/metadata-action@v4 | |
with: | |
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} | |
tags: | | |
type=raw,value=preprod,enable=true | |
- name: Build and push preprod Docker | |
uses: docker/build-push-action@v4 | |
with: | |
file: ./deployment/Dockerfile | |
context: . | |
push: true | |
build-args: | | |
BUILD_MODE=production | |
LAUNCH_MODE=preprod | |
APP_VERSION=${{ github.ref_name }} | |
tags: ${{ steps.meta-preprod.outputs.tags }} | |
labels: ${{ steps.meta-preprod.outputs.labels }} | |
build-prod-image: | |
name: Собираем production Docker | |
runs-on: ubuntu-latest | |
permissions: | |
contents: read | |
packages: write | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
- name: Log in to the Container registry | |
uses: docker/login-action@v2 | |
with: | |
registry: ${{ env.REGISTRY }} | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Define production metadata | |
id: meta-prod | |
uses: docker/metadata-action@v4 | |
with: | |
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} | |
tags: | | |
type=ref,event=tag,enable=true | |
type=raw,value=prod,enable=true | |
type=raw,value=latest,enable=true | |
- name: Build and push production Docker | |
uses: docker/build-push-action@v4 | |
with: | |
file: ./deployment/Dockerfile | |
context: . | |
push: true | |
build-args: | | |
BUILD_MODE=production | |
LAUNCH_MODE=production | |
APP_VERSION=${{ github.ref_name }} | |
tags: ${{ steps.meta-prod.outputs.tags }} | |
labels: ${{ steps.meta-prod.outputs.labels }} | |
deploy-preprod: | |
name: Раскатываем pre-prod среду | |
runs-on: [self-hosted, Linux] | |
needs: build-preprod-image | |
environment: | |
name: Preprod | |
url: https://payments.preprod.profcomff.com/ | |
env: | |
CONTAINER_NAME: com_profcomff_payments_preprod | |
permissions: | |
packages: read | |
steps: | |
- name: Run docker container | |
run: | | |
docker pull ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:preprod | |
docker stop ${{ env.CONTAINER_NAME }} || true && docker rm ${{ env.CONTAINER_NAME }} || true | |
docker run \ | |
--detach \ | |
--restart on-failure:3 \ | |
--network=web \ | |
--name ${{ env.CONTAINER_NAME }} \ | |
${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:preprod | |
undeploy-preprod: | |
name: Останавливаем pre-prod среду | |
runs-on: [self-hosted, Linux] | |
needs: deploy-preprod | |
environment: | |
name: Preprod | |
env: | |
CONTAINER_NAME: com_profcomff_payments_preprod | |
permissions: | |
packages: read | |
steps: | |
- name: Stop docker container | |
run: | | |
docker stop ${{ env.CONTAINER_NAME }} || true && docker rm ${{ env.CONTAINER_NAME }} || true | |
deploy-production: | |
name: Раскатываем production среду | |
runs-on: [self-hosted, Linux] | |
needs: [deploy-preprod, build-prod-image] | |
environment: | |
name: Production | |
url: https://payments.profcomff.com/ | |
env: | |
CONTAINER_NAME: com_profcomff_payments | |
permissions: | |
packages: read | |
steps: | |
- name: Run docker container | |
run: | | |
docker pull ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:prod | |
docker stop ${{ env.CONTAINER_NAME }} || true && docker rm ${{ env.CONTAINER_NAME }} || true | |
docker run \ | |
--detach \ | |
--restart always \ | |
--network=web \ | |
--name ${{ env.CONTAINER_NAME }} \ | |
${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:prod |