Revert "Update ticketing (backend) branch (#612)" #997
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
# Generated by cdkactions. Do not modify | |
# Generated as part of the 'application' stack. | |
name: Build and Deploy | |
on: push | |
jobs: | |
django-check: | |
name: Django Check | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v2 | |
- name: Cache | |
uses: actions/cache@v2 | |
with: | |
path: ~/.local/share/virtualenvs | |
key: v0-${{ hashFiles('backend/Pipfile.lock') }} | |
- name: Install Dependencies | |
run: |- | |
cd backend | |
pip install pipenv | |
pipenv install --deploy --dev | |
- name: Lint (flake8) | |
run: |- | |
cd backend | |
pipenv run flake8 . | |
- name: Lint (black) | |
run: |- | |
cd backend | |
pipenv run black --check . | |
- name: Test (run in parallel) | |
run: |- | |
cd backend | |
pipenv run coverage run --concurrency=multiprocessing manage.py test --settings=pennclubs.settings.ci --parallel | |
pipenv run coverage combine | |
- name: Upload Code Coverage | |
run: |- | |
ROOT=$(pwd) | |
cd backend | |
pipenv run codecov --root $ROOT --flags backend | |
container: | |
image: python:3.8-buster | |
env: | |
DATABASE_URL: postgres://postgres:postgres@postgres:5432/postgres | |
services: | |
postgres: | |
image: postgres:12 | |
env: | |
POSTGRES_USER: postgres | |
POSTGRES_DB: postgres | |
POSTGRES_PASSWORD: postgres | |
options: "--health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5" | |
build-backend: | |
name: Build backend | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v2 | |
- uses: docker/setup-qemu-action@v1 | |
- uses: docker/setup-buildx-action@v1 | |
- name: Cache Docker layers | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/.buildx-cache | |
key: buildx-build-backend | |
- name: Build/Publish | |
uses: docker/build-push-action@v2 | |
with: | |
context: backend | |
file: backend/Dockerfile | |
push: false | |
cache-from: type=local,src=/tmp/.buildx-cache,type=registry,ref=pennlabs/penn-clubs-backend:latest | |
cache-to: type=local,dest=/tmp/.buildx-cache | |
tags: pennlabs/penn-clubs-backend:latest,pennlabs/penn-clubs-backend:${{ github.sha }} | |
outputs: type=docker,dest=/tmp/image.tar | |
- uses: actions/upload-artifact@v2 | |
with: | |
name: build-backend | |
path: /tmp/image.tar | |
needs: django-check | |
react-check: | |
name: React Check | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v2 | |
- name: Cache | |
uses: actions/cache@v2 | |
with: | |
path: "**/node_modules" | |
key: v0-${{ hashFiles('frontend/yarn.lock') }} | |
- name: Install Dependencies | |
run: |- | |
cd frontend | |
yarn install --frozen-lockfile | |
- name: Lint | |
run: |- | |
cd frontend | |
yarn lint | |
- name: Test | |
run: |- | |
cd frontend | |
yarn test | |
- name: Upload Code Coverage | |
run: |- | |
ROOT=$(pwd) | |
cd frontend | |
yarn run codecov -p $ROOT -F frontend | |
container: | |
image: node:14 | |
build-frontend: | |
name: Build frontend | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v2 | |
- uses: docker/setup-qemu-action@v1 | |
- uses: docker/setup-buildx-action@v1 | |
- name: Cache Docker layers | |
uses: actions/cache@v2 | |
with: | |
path: /tmp/.buildx-cache | |
key: buildx-build-frontend | |
- name: Build/Publish | |
uses: docker/build-push-action@v2 | |
with: | |
context: frontend | |
file: frontend/Dockerfile | |
push: false | |
cache-from: type=local,src=/tmp/.buildx-cache,type=registry,ref=pennlabs/penn-clubs-frontend:latest | |
cache-to: type=local,dest=/tmp/.buildx-cache | |
tags: pennlabs/penn-clubs-frontend:latest,pennlabs/penn-clubs-frontend:${{ github.sha }} | |
outputs: type=docker,dest=/tmp/image.tar | |
- uses: actions/upload-artifact@v2 | |
with: | |
name: build-frontend | |
path: /tmp/image.tar | |
needs: react-check | |
integration-tests: | |
name: Integration Tests | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v2 | |
- uses: actions/download-artifact@v2 | |
- name: Load docker images | |
run: |- | |
docker load --input build-backend/image.tar | |
docker load --input build-frontend/image.tar | |
- name: Run docker compose | |
run: |- | |
mkdir -p /tmp/test-results | |
docker-compose -f docker-compose.test.yaml up -d | |
- name: Wait for backend | |
run: |- | |
for try in {1..20}; do | |
docker-compose -f docker-compose.test.yaml exec -T backend python manage.py migrate --check && break | |
sleep 5 | |
done | |
- name: Populate backend | |
run: docker-compose -f docker-compose.test.yaml exec -T backend python manage.py populate | |
- name: Run integration tests | |
run: docker-compose -f docker-compose.test.yaml exec -T frontend yarn integration | |
- name: Delete artifacts when no longer needed | |
if: failure() || github.ref != 'refs/heads/master' | |
uses: geekyeggo/delete-artifact@v1 | |
with: | |
name: |- | |
build-backend | |
build-frontend | |
- name: Print logs on failure | |
if: failure() | |
run: docker-compose -f docker-compose.test.yaml logs | |
- name: Upload artifacts on failure | |
if: failure() | |
uses: actions/upload-artifact@v2 | |
with: | |
name: cypress-output | |
path: /tmp/test-results | |
env: | |
GIT_SHA: ${{ github.sha }} | |
needs: | |
- build-backend | |
- build-frontend | |
post-integration-publish: | |
name: Publish Images | |
runs-on: ubuntu-latest | |
if: github.ref == 'refs/heads/master' | |
steps: | |
- uses: actions/checkout@v2 | |
- uses: actions/download-artifact@v2 | |
- uses: geekyeggo/delete-artifact@v1 | |
with: | |
name: |- | |
build-backend | |
build-frontend | |
- name: Load docker images | |
run: |- | |
docker load --input build-backend/image.tar | |
docker load --input build-frontend/image.tar | |
- uses: docker/login-action@v1 | |
with: | |
username: ${{ secrets.DOCKER_USERNAME }} | |
password: ${{ secrets.DOCKER_PASSWORD }} | |
- name: Push docker images | |
run: |- | |
docker push -a pennlabs/penn-clubs-backend | |
docker push -a pennlabs/penn-clubs-frontend | |
needs: integration-tests | |
deploy: | |
runs-on: ubuntu-latest | |
if: github.ref == 'refs/heads/master' | |
steps: | |
- uses: actions/checkout@v2 | |
- id: synth | |
name: Synth cdk8s manifests | |
run: |- | |
cd k8s | |
yarn install --frozen-lockfile | |
# get repo name (by removing owner/organization) | |
export RELEASE_NAME=${REPOSITORY#*/} | |
# Export RELEASE_NAME as an output | |
echo "::set-output name=RELEASE_NAME::$RELEASE_NAME" | |
yarn build | |
env: | |
GIT_SHA: ${{ github.sha }} | |
REPOSITORY: ${{ github.repository }} | |
AWS_ACCOUNT_ID: ${{ secrets.AWS_ACCOUNT_ID }} | |
- name: Deploy | |
run: |- | |
aws eks --region us-east-1 update-kubeconfig --name production --role-arn arn:aws:iam::${AWS_ACCOUNT_ID}:role/kubectl | |
# get repo name from synth step | |
RELEASE_NAME=${{ steps.synth.outputs.RELEASE_NAME }} | |
# Deploy | |
kubectl apply -f k8s/dist/ -l app.kubernetes.io/component=certificate | |
kubectl apply -f k8s/dist/ --prune -l app.kubernetes.io/part-of=$RELEASE_NAME | |
env: | |
AWS_ACCOUNT_ID: ${{ secrets.AWS_ACCOUNT_ID }} | |
AWS_ACCESS_KEY_ID: ${{ secrets.GH_AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.GH_AWS_SECRET_ACCESS_KEY }} | |
needs: | |
- post-integration-publish |