Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Wf #292

Merged
merged 11 commits into from
Aug 29, 2023
Merged

Wf #292

Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
115 changes: 94 additions & 21 deletions .github/workflows/docker.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -8,17 +8,14 @@ on:
- 'LICENSE'

jobs:
docker:
amd64:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
with:
submodules: true

- name: Set up QEMU
uses: docker/setup-qemu-action@v2

- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2

Expand All @@ -36,13 +33,6 @@ jobs:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}

- name: Login to GitHub Container Registry
uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}

- name: Run hooks
env:
REACT_APP_SENTRY_DSN: ${{ secrets.REACT_APP_SENTRY_DSN }}
Expand All @@ -59,12 +49,6 @@ jobs:
with:
string: ${{ secrets.DOCKERHUB_USERNAME }}/${{ github.event.repository.name }}

- name: Lower case for ghcr
id: ghcr_string
uses: ASzc/change-string-case-action@v5
with:
string: ${{ github.event.repository.full_name }}

- name: Start MongoDB
uses: supercharge/[email protected]
with:
Expand All @@ -78,8 +62,10 @@ jobs:
# for CI purposes, we only need to save amd64 and then build multi-arch later
platforms: linux/amd64
load: true
provenance: false
sbom: false
tags: |
${{ steps.dh_string.outputs.lowercase }}
${{ steps.dh_string.outputs.lowercase }}:ci
build-args: |
env=dev
cache-from: type=local,src=/tmp/.buildx-cache
Expand All @@ -97,11 +83,12 @@ jobs:
uses: docker/build-push-action@v4
with:
context: .
platforms: linux/amd64, linux/arm64
platforms: linux/amd64
push: true
provenance: false
sbom: false
tags: |
${{ steps.dh_string.outputs.lowercase }}
ghcr.io/${{ steps.ghcr_string.outputs.lowercase }}
${{ steps.dh_string.outputs.lowercase }}:amd64
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max

Expand All @@ -110,6 +97,92 @@ jobs:
rm -rf /tmp/.buildx-cache
mv /tmp/.buildx-cache-new /tmp/.buildx-cache



arm64:
runs-on: self-hosted
steps:
- name: Checkout
uses: actions/checkout@v3
with:
submodules: true

- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2

- name: Login to DockerHub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}

- name: Run hooks
env:
REACT_APP_SENTRY_DSN: ${{ secrets.REACT_APP_SENTRY_DSN }}
REACT_APP_DOMAIN: ${{ secrets.REACT_APP_DOMAIN }}
REACT_APP_GA: ${{ secrets.REACT_APP_GA }}
GENERATE_SOURCEMAP: ${{ secrets.GENERATE_SOURCEMAP }}
REACT_APP_ADSENSE: ${{ secrets.REACT_APP_ADSENSE }}
REACT_APP_CRISP: ${{ secrets.REACT_APP_CRISP }}
run: bash scripts/pre_build.sh

- name: Lower case for Docker Hub
id: dh_string
uses: ASzc/change-string-case-action@v5
with:
string: ${{ secrets.DOCKERHUB_USERNAME }}/${{ github.event.repository.name }}

- name: Build and push docker images
uses: docker/build-push-action@v4
with:
context: .
platforms: linux/arm64
push: true
provenance: false
sbom: false
tags: |
${{ steps.dh_string.outputs.lowercase }}:arm64
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max

combine:
runs-on: ubuntu-latest
needs: [ amd64, arm64 ]
steps:
- name: Login to DockerHub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}

- name: Login to GitHub Container Registry
uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}

- name: Lower case for Docker Hub
id: dh_string
uses: ASzc/change-string-case-action@v5
with:
string: ${{ secrets.DOCKERHUB_USERNAME }}/${{ github.event.repository.name }}

- name: Lower case for ghcr
id: ghcr_string
uses: ASzc/change-string-case-action@v5
with:
string: ${{ github.event.repository.full_name }}

- name: Combine two images
run: |
docker manifest create ${{ steps.dh_string.outputs.lowercase }} ${{ steps.dh_string.outputs.lowercase }}:amd64 ${{ steps.dh_string.outputs.lowercase }}:arm64
docker manifest push ${{ steps.dh_string.outputs.lowercase }}

docker pull ${{ steps.dh_string.outputs.lowercase }}
docker tag ${{ steps.dh_string.outputs.lowercase }} ghcr.io/${{ steps.ghcr_string.outputs.lowercase }}
docker push ghcr.io/${{ steps.ghcr_string.outputs.lowercase }}

- name: Notification to Telegram
env:
TOKEN: ${{ secrets.BOT_TOKEN }}
Expand Down
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ release:


ci-test:
docker run --rm bennythink/yyetsbot /bin/sh -c "cd /YYeTsBot/yyetsweb/tests;python -m unittest discover -p '*_test.py'"
docker run --rm bennythink/yyetsbot:ci /bin/sh -c "cd /YYeTsBot/yyetsweb/tests;python -m unittest discover -p '*_test.py'"

test:
cd $(WEB)/tests;python -m unittest discover -p '*_test.py'
Loading