Skip to content

Commit

Permalink
Merge pull request #642 from closeio/gha-workflow-2
Browse files Browse the repository at this point in the history
Github Actions workflow, attempt 2
  • Loading branch information
tsx authored Jan 30, 2024
2 parents b767725 + eb35484 commit ee1a929
Show file tree
Hide file tree
Showing 4 changed files with 327 additions and 10 deletions.
185 changes: 185 additions & 0 deletions .github/workflows/build-and-release.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,185 @@
name: Build and Release

on:
push:
branches:
- '*'

concurrency:
group: build-${{ github.event.pull_request.number || github.ref }}
cancel-in-progress: true

env:
DOCKERHUB_NAMESPACE: closeio
PROJECT: sync-engine
# TODO: Remove this after migration
TAG_SUFFIX: "-gha"

jobs:
static-code-analysis:
runs-on: ubuntu-20.04
steps:
- name: Checkout
uses: actions/checkout@v4

- name: Setup Python
uses: actions/setup-python@v5
with:
python-version: '3.8'
architecture: 'x64'

- name: Install dependencies
run: |
python -m pip install --upgrade pip
python -m pip install --no-deps -r requirements/lint.txt
- name: Run Black
run: black --check .

- name: Run isort
run: isort -c .

- name: Run flake8
run: flake8


build:
runs-on: ubuntu-20.04

strategy:
matrix:
include:
- arch: amd64
build_name: py3.7
dockerhub_push: false
python_version: "3.7"
run_tests: true
- arch: amd64
build_name: py3.8
dockerhub_push: true
python_version: "3.8"
run_tests: true
- arch: amd64
build_name: py3.9
dockerhub_push: false
python_version: "3.9"
run_tests: true

# The qemu arm64 builds are *very* slow so they are split out into
# their own workflow

# - arch: arm64
# build_name: py3.8
# dockerhub_push: true
# python_version: "3.8"
# run_tests: false

steps:
- name: Checkout
uses: actions/checkout@v4

- name: Get short sha
id: vars
run: |
echo ::set-output name=sha_short::${GITHUB_SHA::16}
shell: bash

- name: Prepare environment
run: |
if [ "$(git log -1 --pretty=%B | head -n 1 | grep '#notests')" ]; then
echo 'SKIP_TESTS="1"' >> $GITHUB_ENV
fi
echo "DOCKER_IMAGE_TAG=${{ env.DOCKERHUB_NAMESPACE }}/${{ env.PROJECT }}:${{ steps.vars.outputs.sha_short }}-${{ matrix.build_name}}${{ env.TAG_SUFFIX }}-${{ matrix.arch }}" >> $GITHUB_ENV
shell: bash

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

- name: Set up Docker context for Buildx
id: buildx-context
run: |
docker context create container-builder
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
with:
version: latest
endpoint: container-builder

- name: Login to DockerHub
# if: ${{ github.ref == 'master' && github.event.pull_request.merged == true }}
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}

- name: Build and push sync-engine images
uses: docker/build-push-action@v5
with:
platforms: linux/${{ matrix.arch }}
push: false
load: true
build-args:
PYTHON_VERSION=${{ matrix.python_version }}
tags: |
${{ env.DOCKER_IMAGE_TAG }}
cache-from: type=gha
cache-to: type=gha,mode=max

- name: Run tests
if: ${{ matrix.run_tests }}
run: |
docker tag ${{ env.DOCKER_IMAGE_TAG }} ${{ env.PROJECT }}_app
if [[ -z $SKIP_TESTS ]]; then
docker-compose run app bash -ec '
bin/wait-for-it.sh mysql:3306 \
&& NYLAS_ENV=test pytest --cov-report= --cov=inbox tests/ \
&& coverage html -d pythoncov
'
else
echo Skipping tests
fi
- name: Push image
if: ${{ matrix.dockerhub_push }}
run: |
docker push ${{ env.DOCKER_IMAGE_TAG }}
multi-arch-manifest:
needs:
- build

runs-on: ubuntu-20.04

strategy:
matrix:
include:
- build_name: py3.8

steps:
- name: Get short sha
id: vars
run: |
echo ::set-output name=sha_short::${GITHUB_SHA::16}
shell: bash

- name: Prepare environment
run: |
if [ "$(git log -1 --pretty=%B | head -n 1 | grep '#notests')" ]; then
echo 'SKIP_TESTS="1"' >> $GITHUB_ENV
fi
echo "DOCKER_IMAGE_TAG=${{ env.DOCKERHUB_NAMESPACE }}/${{ env.PROJECT }}:${{ steps.vars.outputs.sha_short }}-${{ matrix.build_name}}${{ env.TAG_SUFFIX }}" >> $GITHUB_ENV
shell: bash

- name: Login to DockerHub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}

- name: Create manifest
run: |
docker buildx imagetools create \
-t ${{ env.DOCKER_IMAGE_TAG }} \
${{ env.DOCKER_IMAGE_TAG }}-amd64
# ${{ env.DOCKER_IMAGE_TAG }}-arm64
140 changes: 140 additions & 0 deletions .github/workflows/build-arm64.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,140 @@
name: Build arm64

on:
push:
branches:
- '*'

concurrency:
group: build-arm64-${{ github.event.pull_request.number || github.ref }}
cancel-in-progress: true

env:
DOCKERHUB_NAMESPACE: closeio
PROJECT: sync-engine
# TODO: Remove this after migration
TAG_SUFFIX: "-gha"

jobs:
build-arm64:
runs-on: ubuntu-20.04

strategy:
matrix:
include:
- arch: arm64
build_name: py3.8
dockerhub_push: true
python_version: "3.8"
run_tests: false

steps:
- name: Checkout
uses: actions/checkout@v4

- name: Get short sha
id: vars
run: |
echo ::set-output name=sha_short::${GITHUB_SHA::16}
shell: bash

- name: Prepare environment
run: |
if [ "$(git log -1 --pretty=%B | head -n 1 | grep '#notests')" ]; then
echo 'SKIP_TESTS="1"' >> $GITHUB_ENV
fi
echo "DOCKER_IMAGE_TAG=${{ env.DOCKERHUB_NAMESPACE }}/${{ env.PROJECT }}:${{ steps.vars.outputs.sha_short }}-${{ matrix.build_name}}${{ env.TAG_SUFFIX }}-${{ matrix.arch }}" >> $GITHUB_ENV
shell: bash

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

- name: Set up Docker context for Buildx
id: buildx-context
run: |
docker context create container-builder
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
with:
version: latest
endpoint: container-builder

- name: Login to DockerHub
# if: ${{ github.ref == 'master' && github.event.pull_request.merged == true }}
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}

- name: Build and push sync-engine images
uses: docker/build-push-action@v5
with:
platforms: linux/${{ matrix.arch }}
push: false
load: true
build-args:
PYTHON_VERSION=${{ matrix.python_version }}
tags: |
${{ env.DOCKER_IMAGE_TAG }}
cache-from: type=gha
cache-to: type=gha,mode=max

- name: Run tests
if: ${{ matrix.run_tests }}
run: |
docker tag ${{ env.DOCKER_IMAGE_TAG }} ${{ env.PROJECT }}_app
if [[ -z $SKIP_TESTS ]]; then
docker-compose run app bash -ec '
bin/wait-for-it.sh mysql:3306 \
&& NYLAS_ENV=test pytest --cov-report= --cov=inbox tests/ \
&& coverage html -d pythoncov
'
else
echo Skipping tests
fi
- name: Push image
if: ${{ matrix.dockerhub_push }}
run: |
docker push ${{ env.DOCKER_IMAGE_TAG }}
multi-arch-manifest:
needs:
- build-arm64

runs-on: ubuntu-20.04

strategy:
matrix:
include:
- build_name: py3.8

steps:
- name: Get short sha
id: vars
run: |
echo ::set-output name=sha_short::${GITHUB_SHA::16}
shell: bash

- name: Prepare environment
run: |
if [ "$(git log -1 --pretty=%B | head -n 1 | grep '#notests')" ]; then
echo 'SKIP_TESTS="1"' >> $GITHUB_ENV
fi
echo "DOCKER_IMAGE_TAG=${{ env.DOCKERHUB_NAMESPACE }}/${{ env.PROJECT }}:${{ steps.vars.outputs.sha_short }}-${{ matrix.build_name}}${{ env.TAG_SUFFIX }}" >> $GITHUB_ENV
shell: bash

- name: Login to DockerHub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}

# Because the arm64 builds are so much slower, we assume they will just
# be appended to the existing manifest created by `build-and-release.yaml`.
- name: Create manifest
run: |
docker buildx imagetools create --append \
-t ${{ env.DOCKER_IMAGE_TAG }} \
${{ env.DOCKER_IMAGE_TAG }}-arm64
2 changes: 2 additions & 0 deletions requirements/lint.txt
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,9 @@ flake8-tidy-imports==4.10.0
mccabe==0.7.0
mypy==1.8.0
regex==2023.12.25
packaging==23.2
pathspec==0.12.1
platformdirs==4.1.0
pyflakes==3.2.0
pycodestyle==2.9.1
toml==0.10.2
Expand Down
10 changes: 0 additions & 10 deletions tests/test_misc.py
Original file line number Diff line number Diff line change
@@ -1,18 +1,8 @@
import pytest
import setproctitle

from inbox.models.backends.oauth import hash_token


def test_setproctitle_works():
original_proctitle = setproctitle.getproctitle()

setproctitle.setproctitle(test_setproctitle_works.__name__)
assert setproctitle.getproctitle() == test_setproctitle_works.__name__

setproctitle.setproctitle(original_proctitle)


@pytest.mark.parametrize(
"prefix,token,expected",
[
Expand Down

0 comments on commit ee1a929

Please sign in to comment.