-
Notifications
You must be signed in to change notification settings - Fork 0
146 lines (116 loc) · 3.53 KB
/
ci.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
name: CI
on:
pull_request:
push:
branches: [main]
jobs:
stylelint:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Node
uses: actions/setup-node@v4
with:
node-version-file: ".node-version"
cache: yarn
- name: Install Yarn packages
run: npx --yes ci
- name: Lint CSS files with stylelint
run: yarn lint:css
eslint:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Node
uses: actions/setup-node@v4
with:
node-version-file: ".node-version"
cache: yarn
- name: Install Yarn packages
run: npx --yes ci
- name: Lint JavaScript files with eslint
run: yarn lint:js
scan_gems:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Ruby
uses: ruby/setup-ruby@v1
with:
ruby-version: .ruby-version
bundler-cache: true
- name: Scan for security vulnerabilities in Ruby dependencies
run: bundle exec bundle-audit check --update -v
test:
runs-on: ubuntu-latest
env:
TEST_DATABASE: peace_boilerplate_test
TEST_DATABASE_USERNAME: postgres
TEST_DATABASE_PASSWORD: postgres
TEST_DATABASE_HOST: localhost
services:
postgres:
image: postgres
env:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: postgres
ports:
- 5432:5432
options: --health-cmd="pg_isready" --health-interval=10s --health-timeout=5s --health-retries=3
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Ruby
uses: ruby/setup-ruby@v1
with:
ruby-version: .ruby-version
bundler-cache: true
- name: Set up Node
uses: actions/setup-node@v4
with:
node-version-file: ".node-version"
cache: yarn
- name: Install Yarn packages
run: npx --yes ci
- name: Set up database.yml
run: |
echo "test:" > config/database.yml
echo " adapter: postgresql" >> config/database.yml
echo " encoding: unicode" >> config/database.yml
echo " database: ${TEST_DATABASE}" >> config/database.yml
echo " pool: 5" >> config/database.yml
echo " username: ${TEST_DATABASE_USERNAME}" >> config/database.yml
echo " password: ${TEST_DATABASE_PASSWORD}" >> config/database.yml
echo " host: ${TEST_DATABASE_HOST:-localhost}" >> config/database.yml
- name: Run tests
env:
RAILS_ENV: test
DATABASE_URL: postgres://postgres:postgres@localhost:5432
run: bin/rails db:test:prepare && bin/rspec
scan_ruby:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Ruby
uses: ruby/setup-ruby@v1
with:
ruby-version: .ruby-version
bundler-cache: true
- name: Scan for common Rails security vulnerabilities using static analysis
run: bin/brakeman --no-pager
lint:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Ruby
uses: ruby/setup-ruby@v1
with:
ruby-version: .ruby-version
bundler-cache: true
- name: Lint code for consistent style
run: bin/rubocop -f github