use action #1871
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: CI | |
on: | |
push: | |
# on: | |
# workflow_dispatch: | |
# pull_request: | |
# push: | |
# branches: [main] | |
permissions: | |
pull-requests: write | |
contents: write | |
env: | |
CC_TEST_REPORTER_ID: ${{ secrets.CC_TEST_REPORTER_ID }} | |
CI: true | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
REPO: ${{ github.repository }} | |
PARALLEL_TEST_FIRST_IS_1: true | |
jobs: | |
docker-build: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Cache Docker layers | |
uses: actions/cache@v4 | |
with: | |
path: /tmp/.prod-buildx-cache | |
key: prod-${{ runner.os }}-buildx-${{ github.head_ref || github.ref_name }}-${{ github.sha }} | |
restore-keys: | | |
prod-${{ runner.os }}-buildx-${{ github.head_ref || github.ref_name }} | |
prod-${{ runner.os }}-buildx-main | |
prod-${{ runner.os }}-buildx- | |
- name: Build prod Docker image | |
uses: docker/build-push-action@v6 | |
with: | |
push: false | |
cache-from: type=local,src=/tmp/.prod-buildx-cache | |
cache-to: type=local,dest=/tmp/.prod-buildx-cache-new,mode=max | |
file: Dockerfile | |
- # Temp fix | |
# https://github.com/docker/build-push-action/issues/252 | |
# https://github.com/moby/buildkit/issues/1896 | |
name: Move cache | |
run: | | |
rm -rf /tmp/.prod-buildx-cache | |
mv /tmp/.prod-buildx-cache-new /tmp/.prod-buildx-cache | |
docker: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Set up Docker Buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: Cache Docker layers | |
uses: actions/cache@v4 | |
with: | |
path: /tmp/.buildx-cache | |
key: ${{ runner.os }}-buildx-${{ github.head_ref || github.ref_name }}-${{ github.sha }} | |
restore-keys: | | |
${{ runner.os }}-buildx-${{ github.head_ref || github.ref_name }} | |
${{ runner.os }}-buildx-main | |
${{ runner.os }}-buildx- | |
- name: Build and export | |
uses: docker/build-push-action@v6 | |
with: | |
push: false | |
tags: api_base/test:latest | |
cache-from: type=local,src=/tmp/.buildx-cache | |
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max | |
outputs: type=docker,dest=/tmp/api_base_test_image.tar | |
file: Dockerfile.dev | |
- name: Upload artifact | |
uses: actions/upload-artifact@v4 | |
with: | |
name: api base test image | |
path: /tmp/api_base_test_image.tar | |
retention-days: 1 | |
- # Temp fix | |
# https://github.com/docker/build-push-action/issues/252 | |
# https://github.com/moby/buildkit/issues/1896 | |
name: Move cache | |
run: | | |
rm -rf /tmp/.buildx-cache | |
mv /tmp/.buildx-cache-new /tmp/.buildx-cache | |
linters: | |
name: Linters | |
runs-on: ubuntu-latest | |
needs: docker | |
timeout-minutes: 10 | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Download artifact | |
uses: actions/download-artifact@v4 | |
with: | |
name: api base test image | |
path: /tmp | |
- name: Load image | |
run: | | |
docker load --input /tmp/api_base_test_image.tar | |
docker image ls -a | |
- name: Run Code Analysis | |
uses: ./.github/actions/docker-run | |
with: | |
run: bundle exec rails code:analysis | |
tests: | |
name: Tests | |
needs: docker | |
runs-on: ubuntu-latest | |
timeout-minutes: 20 | |
services: | |
db: | |
image: postgres:15 | |
env: | |
POSTGRES_USER: postgres | |
POSTGRES_HOST_AUTH_METHOD: trust | |
ports: | |
- 5432:5432 | |
options: >- | |
--health-cmd pg_isready | |
--health-interval 10s | |
--health-timeout 5s | |
--health-retries 5 | |
chrome-server: | |
image: seleniarm/standalone-chromium | |
ports: | |
- 4444:4444 | |
- 7900:7900 | |
- 5900:5900 | |
strategy: | |
fail-fast: false | |
matrix: | |
# Set N number of parallel jobs you want to run tests on. | |
# Use higher number if you have slow tests to split them on more parallel jobs. | |
# Remember to update ci_node_index below to 0..N-1 | |
ci_node_total: [1] | |
# set N-1 indexes for parallel jobs | |
# When you run 2 parallel jobs then first job will have index 0, the second job will have index 1 etc | |
ci_node_index: [0] | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Download artifact | |
uses: actions/download-artifact@v4 | |
with: | |
name: api base test image | |
path: /tmp | |
- name: Load image | |
run: | | |
docker load --input /tmp/api_base_test_image.tar | |
docker image ls -a | |
- name: Set ENV for API Docs | |
if: github.event_name == 'push' && github.ref == 'refs/heads/main' | |
run: | | |
if [ $(git diff ${{ github.event.before }} ${{ github.event.after }} --name-only | grep 'spec/requests/api' | wc -l) -gt 0 ]; then | |
echo "OPENAPI=true" >> $GITHUB_ENV | |
fi | |
- name: Setup Code Climate test-reporter | |
run: | | |
curl -L https://codeclimate.com/downloads/test-reporter/test-reporter-latest-linux-amd64 > ./cc-test-reporter | |
chmod +x ./cc-test-reporter | |
./cc-test-reporter before-build | |
# - name: Let Rails generate the secret_key_base | |
# run: bundle exec rails runner 'puts Rails.application.secret_key_base' | |
- name: Setup Database | |
uses: ./.github/actions/docker-run | |
with: | |
run: bundle exec rake parallel:create parallel:migrate | |
- name: Check for untracked changes in schema.rb | |
uses: rootstrap/check_untracked_changes@v1 | |
with: | |
path: "./db/schema.rb" | |
- name: Get CPU info | |
id: cpu_info | |
run: echo "cpu_cores=$(nproc)" >> $GITHUB_ENV | |
- name: This is the worst patch ever | |
run: | | |
docker run -it -d --name rails_app api_base/test:latest "sleep infinity" | |
docker container cp rails_app:/src/app/app/assets/builds/. app/assets/builds | |
docker rm -f rails_app | |
- name: Run Tests | |
env: | |
KNAPSACK_CI_NODE_TOTAL: ${{ matrix.ci_node_total }} | |
KNAPSACK_CI_NODE_INDEX: ${{ matrix.ci_node_index }} | |
PARALLEL_TESTS_CONCURRENCY: ${{ env.cpu_cores }} | |
HEADLESS: true | |
SELENIUM_BROWSER_HOST: http://chrome-server:4444 | |
SELENIUM_BROWSER: remote | |
POSTGRES_HOST: db | |
RAILS_ENV: test | |
uses: ./.github/actions/docker-run | |
with: | |
run: bundle exec parallel_rspec -n $PARALLEL_TESTS_CONCURRENCY -e './bin/parallel_tests' | |
- name: Check for missing annotations | |
uses: ./.github/actions/docker-run | |
with: | |
run: bundle exec annotate | |
- name: Check for untracked changes in app and spec directories | |
uses: rootstrap/check_untracked_changes@v1 | |
with: | |
path: "./app/ ./spec/" | |
- name: Upload partial coverage | |
uses: actions/upload-artifact@v4 | |
with: | |
name: coverage | |
path: "coverage/coverage.${{ matrix.ci_node_index }}.json" | |
- name: Merge API Docs from threads | |
env: | |
CI_NODE_INDEX: ${{ matrix.ci_node_index }} | |
if: ${{ env.OPENAPI }} | |
run: bundle exec ./bin/merge-api-docs.rb | |
- name: Upload partial API Docs | |
if: ${{ env.OPENAPI }} | |
uses: actions/upload-artifact@v4 | |
with: | |
name: api_docs | |
path: "tmp/openapi${{ matrix.ci_node_index }}.yaml" | |
merge_results: | |
name: Merge Results | |
runs-on: ubuntu-latest | |
needs: tests | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
ssh-key: "${{ secrets.PUSH_KEY }}" | |
- name: Set ENV for CodeClimate | |
if: github.event_name == 'pull_request' | |
run: | | |
git fetch --no-tags --prune --depth=1 origin +refs/heads/$GITHUB_HEAD_REF:refs/remotes/origin/$GITHUB_HEAD_REF | |
echo "GIT_BRANCH=$GITHUB_HEAD_REF" >> $GITHUB_ENV | |
echo "GIT_COMMIT_SHA=$(git rev-parse origin/$GITHUB_HEAD_REF)" >> $GITHUB_ENV | |
echo "PULL_REQUEST_NUMBER=${{ github.event.pull_request.number }}" >> $GITHUB_ENV | |
- name: Set ENV for API Docs | |
if: github.event_name == 'push' && github.ref == 'refs/heads/main' | |
run: | | |
if [ $(git diff ${{ github.event.before }} ${{ github.event.after }} --name-only | grep 'spec/requests/api' | wc -l) -gt 0 ]; then | |
echo "OPENAPI=true" >> $GITHUB_ENV | |
fi | |
- name: Setup Code Climate test-reporter | |
run: | | |
curl -L https://codeclimate.com/downloads/test-reporter/test-reporter-latest-linux-amd64 > ./cc-test-reporter | |
chmod +x ./cc-test-reporter | |
- name: Download coverage reports | |
uses: actions/download-artifact@v4 | |
with: | |
name: coverage | |
path: coverage/coverage.*.json | |
- name: Report coverage | |
run: | | |
./cc-test-reporter sum-coverage coverage/**/*.json | |
./cc-test-reporter upload-coverage | |
- name: Download artifact | |
uses: actions/download-artifact@v4 | |
with: | |
name: api base test image | |
path: /tmp | |
- name: Load image | |
run: | | |
docker load --input /tmp/api_base_test_image.tar | |
docker image ls -a | |
- name: Download API Docs | |
if: ${{ env.OPENAPI }} | |
uses: actions/download-artifact@v4 | |
with: | |
name: api_docs | |
path: tmp/ | |
- name: Merge API Docs from nodes | |
env: | |
MOVE_TMP_FILES: true | |
if: ${{ env.OPENAPI }} | |
uses: ./.github/actions/docker-run | |
with: | |
run: bundle exec ./bin/merge-api-docs.rb | |
- name: Commit & push API Docs | |
if: ${{ env.OPENAPI }} | |
run: | | |
git config --local user.email "action@github.com" | |
git config --local user.name "GitHub Action" | |
git add "doc/openapi.yaml" | |
git commit -m "Update API Docs" || echo "No changes to commit" | |
git push origin main |