-
Notifications
You must be signed in to change notification settings - Fork 0
129 lines (105 loc) · 3.35 KB
/
backend_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
name: Backend_CI
on:
pull_request:
push:
jobs:
scan_ruby:
if: github.event_name == 'pull_request'
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Ruby
uses: ruby/setup-ruby@v1
with:
working-directory: ./todo_backend
ruby-version: 3.3.4
bundler-cache: true
- name: Change permissions
working-directory: ./todo_backend
run: chmod +x bin/brakeman
- name: Scan for common Rails security vulnerabilities using static analysis
working-directory: ./todo_backend
run: bin/brakeman --no-pager --no-exit-on-warn --no-exit-on-error
# scan_js:
# runs-on: ubuntu-latest
# steps:
# - name: Checkout code
# uses: actions/checkout@v4
# - name: Set up Ruby
# uses: ruby/setup-ruby@v1
# with:
# working-directory: ./todo_backend
# ruby-version: 3.3.4
# bundler-cache: true
# - name: Scan for security vulnerabilities in JavaScript dependencies
# working-directory: ./todo_backend
# run: bin/importmap audit
lint:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Ruby
uses: ruby/setup-ruby@v1
with:
working-directory: ./todo_backend
ruby-version: 3.3.4
bundler-cache: true
- name: Change permissions
working-directory: ./todo_backend
run: chmod +x bin/rubocop
- name: Lint code for consistent style
working-directory: ./todo_backend
run: bin/rubocop
test:
runs-on: ubuntu-latest
services:
db:
image: mysql
env:
MYSQL_ROOT_PASSWORD: rootpasswd
ports:
- 3306:3306
options: --health-cmd="mysqladmin ping" --health-interval=5s --health-timeout=5s --health-retries=1
# redis:
# image: redis
# ports:
# - 6379:6379
# options: --health-cmd "redis-cli ping" --health-interval 10s --health-timeout 5s --health-retries 5
steps:
# - name: Install packages
# run: sudo apt-get update && sudo apt-get install --no-install-recommends -y google-chrome-stable curl default-mysql-client libjemalloc2 libvips
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Ruby
uses: ruby/setup-ruby@v1
with:
working-directory: ./todo_backend
ruby-version: 3.3.4
bundler-cache: true
- name: Change permissions
working-directory: ./todo_backend
run: |
chmod +x bin/rails
chmod +x bin/bundle
- name: Create database
working-directory: ./todo_backend
env:
RAILS_ENV: test
DATABASE_ADDR: '127.0.0.1'
run: bin/rails db:create
- name: Run tests
working-directory: ./todo_backend
env:
RAILS_ENV: test
DATABASE_ADDR: '127.0.0.1'
# REDIS_URL: redis://localhost:6379/0
run: bin/bundle exec rspec
# - name: Keep screenshots from failed system tests
# uses: actions/upload-artifact@v4
# if: failure()
# with:
# name: screenshots
# path: ${{ github.workspace }}/tmp/screenshots
# if-no-files-found: ignore