-
Notifications
You must be signed in to change notification settings - Fork 11
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
93 changed files
with
4,625 additions
and
789 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,327 @@ | ||
name: Build and Run Tests | ||
|
||
on: | ||
schedule: | ||
- cron: '0 5 * * *' #Runs daily at 5 AM UTC | ||
push: | ||
branches: | ||
- master | ||
- develop | ||
pull_request: | ||
branches: | ||
- develop | ||
|
||
env: | ||
CC_TEST_REPORTER_ID: "${{ secrets.CC_TEST_REPORTER_ID }}" | ||
|
||
jobs: | ||
functional-tests: | ||
runs-on: ubuntu-latest | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- name: Configure AWS Credentials | ||
uses: aws-actions/configure-aws-credentials@v4 | ||
with: | ||
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||
role-to-assume: ${{ secrets.AWS_ROLE_TO_ASSUME }} | ||
aws-region: eu-west-1 | ||
|
||
- name: Login to Amazon ECR | ||
id: login-ecr | ||
uses: aws-actions/amazon-ecr-login@v2 | ||
|
||
- name: Set up QEMU | ||
uses: docker/setup-qemu-action@v3 | ||
|
||
- name: Set up Docker Buildx | ||
uses: docker/setup-buildx-action@v3 | ||
|
||
- name: Set up Enviroments | ||
run: | | ||
export RECORD_RUNTIME=true | ||
export LC_ALL=C.UTF-8 | ||
export LANG=C.UTF-8 | ||
export LANGUAGE=C.UTF-8 | ||
export PATH=/root/.local/bin:$PATH | ||
rm -rf tmp/cache tmp/cache1 tmp/cache2 tmp/cache3 tmp/cache4 tmp/cache5 && mkdir -p tmp/cache tmp/cache1 tmp/cache2 tmp/cache3 tmp/cache4 tmp/cache5 | ||
- name: Set up Configuration Files | ||
run: | | ||
cp config/config.yml.example config/config.yml | ||
cp config/database.yml.example config/database.yml | ||
cp config/sidekiq.yml.example config/sidekiq.yml | ||
cp config/credentials.json.example config/credentials.json | ||
cp config/sidekiq-test.yml.example config/sidekiq-test.yml | ||
- name: Build Docker Container | ||
run: | | ||
docker compose build | ||
- name: Run syntax checks | ||
run: | | ||
docker compose run api bash -c 'touch /tmp/no-syntax-errors && find app lib config -name *.rb -exec bash -c "ruby -c {} >/dev/null || rm /tmp/no-syntax-errors" ";" && ls /tmp/no-syntax-errors' | ||
- name: Run Container | ||
run: docker compose -f docker-compose.yml -f docker-test.yml up -d | ||
|
||
- name: Wait for the server to be ready | ||
run: | | ||
tail -f log/test.log & | ||
until curl --silent -I -f --fail http://localhost:3000 ; do printf .; sleep 1; done | ||
- name: Set up parallel environment | ||
run: docker compose exec -T api test/setup-parallel-env.sh | ||
|
||
- name: Precompile Assets | ||
run: docker compose exec -T api bundle exec rake assets:precompile | ||
|
||
- name: Prepare Parallel Runtime Log | ||
run: | | ||
sleep 10 | ||
touch tmp/parallel_runtime_test.log | ||
chmod +w tmp/parallel_runtime_test.log | ||
- name: Run Functional Tests | ||
id: functional-tests | ||
env: | ||
TEST_RETRY_COUNT: 3 | ||
run: | | ||
docker compose exec -e TEST_RETRY_COUNT=$TEST_RETRY_COUNT -T -e PATTERN='models mailers integration workers lib contract' api test/run-tests.sh | ||
- name: After Functional Test | ||
env: | ||
GITHUB_EVENT: ${{ github.event_name}} | ||
GIT_BRANCH: ${{ github.head_ref || github.ref_name }} | ||
GITHUB_REPO: ${{ github.repository }} | ||
GITHUB_TEST_RESULT: ${{ steps.functional-tests.outcome}} | ||
GITHUB_BUILD_NUMBER: ${{ github.run_number }} | ||
GITHUB_COMMIT_SHA: ${{ github.sha }} | ||
GITHUB_JOB_NAME: ${{ github.job }} | ||
CC_TEST_REPORTER_ID: ${{ secrets.CC_TEST_REPORTER_ID }} | ||
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||
ROLE_TO_ASSUME: ${{ secrets.AWS_ROLE_TO_ASSUME }} | ||
AWS_REGION: eu-west-1 | ||
run: | | ||
docker compose exec -T -e GIT_BRANCH=$GIT_BRANCH \ | ||
-e GITHUB_EVENT=$GITHUB_EVENT \ | ||
-e GITHUB_TEST_RESULT=$GITHUB_TEST_RESULT \ | ||
-e GITHUB_REPO=$GITHUB_REPO \ | ||
-e GITHUB_BUILD_NUMBER=$GITHUB_BUILD_NUMBER \ | ||
-e GIT_COMMIT_SHA=$GITHUB_COMMIT_SHA \ | ||
-e CC_TEST_REPORTER_ID=$CC_TEST_REPORTER_ID \ | ||
-e GITHUB_JOB_NAME=$GITHUB_JOB_NAME \ | ||
-e AWS_ACCESS_KEY_ID=$AWS_ACCESS_KEY_ID \ | ||
-e AWS_SECRET_ACCESS_KEY=$AWS_SECRET_ACCESS_KEY \ | ||
-e ROLE_TO_ASSUME=$AWS_ROLE_TO_ASSUME \ | ||
-e AWS_REGION=$AWS_REGION \ | ||
-e AWS_CONFIG_FILE=/app/credentials api test/test-coverage.sh | ||
|
||
unit-tests: | ||
runs-on: ubuntu-latest | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- name: Configure AWS Credentials | ||
uses: aws-actions/configure-aws-credentials@v4 | ||
with: | ||
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||
role-to-assume: ${{ secrets.AWS_ROLE_TO_ASSUME }} | ||
aws-region: eu-west-1 | ||
|
||
- name: Login to Amazon ECR | ||
id: login-ecr | ||
uses: aws-actions/amazon-ecr-login@v2 | ||
|
||
- name: Set up QEMU | ||
uses: docker/setup-qemu-action@v3 | ||
|
||
- name: Set up Docker Buildx | ||
uses: docker/setup-buildx-action@v3 | ||
|
||
- name: set up enviromnts | ||
run: | | ||
export RECORD_RUNTIME=true | ||
export LC_ALL=C.UTF-8 | ||
export LANG=C.UTF-8 | ||
export LANGUAGE=C.UTF-8 | ||
export PATH=/root/.local/bin:$PATH | ||
rm -rf tmp/cache tmp/cache1 tmp/cache2 tmp/cache3 tmp/cache4 tmp/cache5 && mkdir -p tmp/cache tmp/cache1 tmp/cache2 tmp/cache3 tmp/cache4 tmp/cache5 | ||
- name: Set up Configuration Files | ||
run: | | ||
cp config/config.yml.example config/config.yml | ||
cp config/database.yml.example config/database.yml | ||
cp config/sidekiq.yml.example config/sidekiq.yml | ||
cp config/credentials.json.example config/credentials.json | ||
cp config/sidekiq-test.yml.example config/sidekiq-test.yml | ||
- name: Build Docker Container | ||
run: | | ||
docker compose build | ||
- name: Run syntax checks | ||
run: | | ||
docker compose run api bash -c 'touch /tmp/no-syntax-errors && find app lib config -name *.rb -exec bash -c "ruby -c {} >/dev/null || rm /tmp/no-syntax-errors" ";" && ls /tmp/no-syntax-errors' | ||
- name: Run Container | ||
run: docker compose -f docker-compose.yml -f docker-test.yml up -d | ||
|
||
- name: Wait for the server to be ready | ||
run: | | ||
tail -f log/test.log & | ||
until curl --silent -I -f --fail http://localhost:3000 ; do printf .; sleep 1; done | ||
- name: Set up parallel environment | ||
run: docker compose exec -T api test/setup-parallel-env.sh | ||
|
||
- name: Precompile Assets | ||
run: docker compose exec -T api bundle exec rake assets:precompile | ||
|
||
- name: Prepare Parallel Runtime Log | ||
run: | | ||
sleep 10 | ||
touch tmp/parallel_runtime_test.log | ||
chmod +w tmp/parallel_runtime_test.log | ||
- name: Run Unit Tests | ||
id: unit-tests | ||
env: | ||
TEST_RETRY_COUNT: 3 | ||
run: | | ||
docker compose exec -e TEST_RETRY_COUNT=$TEST_RETRY_COUNT -T -e PATTERN='controllers contract' api test/run-tests.sh | ||
- name: After Unit Test | ||
env: | ||
GITHUB_EVENT: ${{ github.event_name}} | ||
GIT_BRANCH: ${{ github.head_ref || github.ref_name }} | ||
GITHUB_REPO: ${{ github.repository }} | ||
GITHUB_TEST_RESULT: ${{ steps.unit-tests.outcome}} | ||
GITHUB_BUILD_NUMBER: ${{ github.run_number }} | ||
GITHUB_COMMIT_SHA: ${{ github.sha }} | ||
GITHUB_JOB_NAME: ${{ github.job }} | ||
CC_TEST_REPORTER_ID: ${{ secrets.CC_TEST_REPORTER_ID }} | ||
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||
ROLE_TO_ASSUME: ${{ secrets.AWS_ROLE_TO_ASSUME }} | ||
AWS_REGION: eu-west-1 | ||
run: | | ||
docker compose exec -T -e GIT_BRANCH=$GIT_BRANCH \ | ||
-e GITHUB_EVENT=$GITHUB_EVENT \ | ||
-e GITHUB_TEST_RESULT=$GITHUB_TEST_RESULT \ | ||
-e GITHUB_REPO=$GITHUB_REPO \ | ||
-e GITHUB_BUILD_NUMBER=$GITHUB_BUILD_NUMBER \ | ||
-e GIT_COMMIT_SHA=$GITHUB_COMMIT_SHA \ | ||
-e CC_TEST_REPORTER_ID=$CC_TEST_REPORTER_ID \ | ||
-e GITHUB_JOB_NAME=$GITHUB_JOB_NAME \ | ||
-e AWS_ACCESS_KEY_ID=$AWS_ACCESS_KEY_ID \ | ||
-e AWS_SECRET_ACCESS_KEY=$AWS_SECRET_ACCESS_KEY \ | ||
-e ROLE_TO_ASSUME=$AWS_ROLE_TO_ASSUME \ | ||
-e AWS_REGION=$AWS_REGION \ | ||
-e AWS_CONFIG_FILE=/app/credentials api test/test-coverage.sh | ||
contract-tests: | ||
runs-on: ubuntu-latest | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- name: Configure AWS Credentials | ||
uses: aws-actions/configure-aws-credentials@v4 | ||
with: | ||
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||
role-to-assume: ${{ secrets.AWS_ROLE_TO_ASSUME }} | ||
aws-region: eu-west-1 | ||
|
||
- name: Login to Amazon ECR | ||
id: login-ecr | ||
uses: aws-actions/amazon-ecr-login@v2 | ||
|
||
- name: Set up QEMU | ||
uses: docker/setup-qemu-action@v3 | ||
|
||
- name: Set up Docker Buildx | ||
uses: docker/setup-buildx-action@v3 | ||
|
||
- name: Set up Enviroments | ||
run: | | ||
export RECORD_RUNTIME=true | ||
export LC_ALL=C.UTF-8 | ||
export LANG=C.UTF-8 | ||
export LANGUAGE=C.UTF-8 | ||
export PATH=/root/.local/bin:$PATH | ||
rm -rf tmp/cache tmp/cache1 tmp/cache2 tmp/cache3 tmp/cache4 tmp/cache5 && mkdir -p tmp/cache tmp/cache1 tmp/cache2 tmp/cache3 tmp/cache4 tmp/cache5 | ||
- name: Set up Configuration Files | ||
run: | | ||
cp config/config.yml.example config/config.yml | ||
cp config/database.yml.example config/database.yml | ||
cp config/sidekiq.yml.example config/sidekiq.yml | ||
cp config/credentials.json.example config/credentials.json | ||
cp config/sidekiq-test.yml.example config/sidekiq-test.yml | ||
- name: Build Docker Container | ||
run: | | ||
docker compose build | ||
- name: Run syntax checks | ||
run: | | ||
docker compose run api bash -c 'touch /tmp/no-syntax-errors && find app lib config -name *.rb -exec bash -c "ruby -c {} >/dev/null || rm /tmp/no-syntax-errors" ";" && ls /tmp/no-syntax-errors' | ||
- name: Run Container | ||
run: docker compose -f docker-compose.yml -f docker-test.yml up -d | ||
|
||
- name: Wait for the server to be ready | ||
run: | | ||
tail -f log/test.log & | ||
until curl --silent -I -f --fail http://localhost:3000 ; do printf .; sleep 1; done | ||
- name: Set up Parallel Environment | ||
run: docker compose exec -T api test/setup-parallel-env.sh | ||
|
||
- name: Precompile Assets | ||
run: docker compose exec -T api bundle exec rake assets:precompile | ||
|
||
- name: Prepare Parallel Runtime Log | ||
run: | | ||
sleep 10 | ||
touch tmp/parallel_runtime_test.log | ||
chmod +w tmp/parallel_runtime_test.log | ||
- name: Run Contract Tests | ||
id: run-tests | ||
env: | ||
TEST_RETRY_COUNT: 3 | ||
run: | | ||
docker compose exec -e TEST_RETRY_COUNT=$TEST_RETRY_COUNT -T -e PATTERN='controllers models mailers integration workers lib' api test/run-tests.sh | ||
- name: After Contract Test | ||
env: | ||
GITHUB_EVENT: ${{ github.event_name}} | ||
GIT_BRANCH: ${{ github.head_ref || github.ref_name }} | ||
GITHUB_REPO: ${{ github.repository }} | ||
GITHUB_TEST_RESULT: ${{ steps.run-tests.outcome}} | ||
GITHUB_BUILD_NUMBER: ${{ github.run_number }} | ||
GITHUB_COMMIT_SHA: ${{ github.sha }} | ||
GITHUB_JOB_NAME: ${{ github.job }} | ||
CC_TEST_REPORTER_ID: ${{ secrets.CC_TEST_REPORTER_ID }} | ||
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | ||
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | ||
ROLE_TO_ASSUME: ${{ secrets.AWS_ROLE_TO_ASSUME }} | ||
AWS_REGION: eu-west-1 | ||
run: | | ||
docker compose exec -T -e GIT_BRANCH=$GIT_BRANCH \ | ||
-e GITHUB_EVENT=$GITHUB_EVENT \ | ||
-e GITHUB_TEST_RESULT=$GITHUB_TEST_RESULT \ | ||
-e GITHUB_REPO=$GITHUB_REPO \ | ||
-e GITHUB_BUILD_NUMBER=$GITHUB_BUILD_NUMBER \ | ||
-e GIT_COMMIT_SHA=$GITHUB_COMMIT_SHA \ | ||
-e CC_TEST_REPORTER_ID=$CC_TEST_REPORTER_ID \ | ||
-e GITHUB_JOB_NAME=$GITHUB_JOB_NAME \ | ||
-e AWS_ACCESS_KEY_ID=$AWS_ACCESS_KEY_ID \ | ||
-e AWS_SECRET_ACCESS_KEY=$AWS_SECRET_ACCESS_KEY \ | ||
-e ROLE_TO_ASSUME=$AWS_ROLE_TO_ASSUME \ | ||
-e AWS_REGION=$AWS_REGION \ | ||
-e AWS_CONFIG_FILE=/app/credentials api test/test-coverage.sh |
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.