ci: include workflow in concurrency group (#512) #1316
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: Rails Template CI | |
on: | |
workflow_dispatch: | |
pull_request: | |
push: | |
branches: | |
- main | |
schedule: | |
# * is a special character in YAML so you have to quote this string | |
# * At 05:00 UTC every Monday, run the latest commit on the default or base branch | |
- cron: '0 5 * * MON' | |
# Restrict jobs in this workflow to only be allowed to read this repo by default. | |
# | |
# If you are wanting to introduce a job/tool that requires more permissions (such | |
# as posting comments or commits to the repository), then you should grant just | |
# that job the necessarily permissions by giving it a dedicated `permissions` block. | |
permissions: | |
contents: read # to fetch code (actions/checkout) | |
jobs: | |
audit_dependencies: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
persist-credentials: false | |
- name: Audit dependencies for security vulnerabilities | |
uses: g-rath/check-with-osv-detector@main | |
test: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
persist-credentials: false | |
- uses: actions/setup-node@v3 | |
with: | |
node-version-file: '.node-version' | |
cache: 'yarn' | |
- run: yarn install | |
- run: yarn run format-check | |
rubocop: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
persist-credentials: false | |
- name: Install Ruby and Bundler | |
uses: ruby/setup-ruby@v1 | |
with: | |
bundler-cache: true | |
ruby-version: 'ruby' | |
- name: Run Rubocop | |
run: bundle exec rubocop | |
test_generated_apps: | |
runs-on: ubuntu-latest | |
strategy: | |
# don't stop all variants if one of them fails (we usually want to know | |
# how many fail) | |
fail-fast: false | |
matrix: | |
variant: | |
- name: defaults | |
config_path: 'ackama_rails_template.config.yml' | |
- name: all | |
config_path: 'ci/configs/all.yml' | |
- name: all-typescript | |
config_path: 'ci/configs/all-typescript.yml' | |
- name: basic | |
config_path: 'ci/configs/basic.yml' | |
- name: basic-typescript | |
config_path: 'ci/configs/basic-typescript.yml' | |
- name: github_actions | |
config_path: 'ci/configs/github_actions.yml' | |
- name: react | |
config_path: 'ci/configs/react.yml' | |
- name: react-typescript | |
config_path: 'ci/configs/react-typescript.yml' | |
- name: sidekiq | |
config_path: 'ci/configs/sidekiq.yml' | |
- name: devise | |
config_path: 'ci/configs/devise.yml' | |
- name: basic_with_skips | |
config_path: 'ci/configs/basic.yml' | |
skips: --skip-spring --skip-javascript | |
- name: bootstrap | |
config_path: 'ci/configs/bootstrap.yml' | |
- name: bootstrap-typescript | |
config_path: 'ci/configs/bootstrap-typescript.yml' | |
- name: capistrano | |
config_path: 'ci/configs/deploy_with_capistrano.yml' | |
- name: ackama_ec2_capistrano | |
config_path: 'ci/configs/deploy_with_ackama_ec2_capistrano.yml' | |
services: | |
db: | |
image: postgres | |
env: | |
# The Postgres service fails its docker health check unless you | |
# specify these environment variables | |
POSTGRES_USER: postgres | |
POSTGRES_PASSWORD: postgres | |
POSTGRES_DB: anything # can be anything, is ignored by the tests | |
ports: ['5432:5432'] | |
# prettier-ignore | |
options: >- | |
--health-cmd pg_isready | |
--health-interval 10s | |
--health-timeout 5s | |
--health-retries 5 | |
steps: | |
- name: Checkout this repo | |
uses: actions/checkout@v3 | |
with: | |
persist-credentials: false | |
# this ensures that osv-detector is available for running bin/ci-run | |
- name: Check dependencies for vulnerabilities (and setup osv-detector) | |
uses: g-rath/check-with-osv-detector@main | |
- name: Install NodeJS | |
uses: actions/setup-node@v3 | |
with: | |
cache: 'yarn' | |
node-version-file: '.node-version' | |
# We don't cache gems or JS packages because we are actually testing how | |
# installation and setup works in this project so, while caching would | |
# make CI faster, it might hide problems. | |
- name: Install Ruby and Bundler | |
uses: ruby/setup-ruby@v1 | |
with: | |
bundler-cache: true | |
ruby-version: 'ruby' | |
- name: Setup git for committing | |
run: | | |
# We do some git commits during our testing so these need to be set | |
git config --global user.email "[email protected]" | |
git config --global user.name "Your Name" | |
- name: Run CI script | |
env: | |
# Remember that your app name becomes a top-level constant in the | |
# Rails app so you'll run into issues if that constant shares a name | |
# with a class provided by a gem. Basically, don't name your app | |
# "react", "sidekiq" etc. | |
APP_NAME: ${{ matrix.variant.name }}-demo | |
CONFIG_PATH: ${{ matrix.variant.config_path }} | |
SKIPS: '--skip-javascript --skip-docker ${{ matrix.variant.skips }}' | |
PGUSER: postgres | |
PGPASSWORD: postgres | |
PGHOST: localhost | |
run: ./ci/bin/build-and-test |