-
Notifications
You must be signed in to change notification settings - Fork 5
139 lines (120 loc) · 4.07 KB
/
tests.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
name: Tests
on:
push:
pull_request:
jobs:
test:
name: ${{ matrix.redmine }} ${{ matrix.db }} ruby-${{ matrix.ruby }}
runs-on: ubuntu-latest
strategy:
matrix:
ruby: ['2.7', '3.0', '3.1']
redmine: ['5.0-stable', 'master']
db: ['postgres', 'mysql']
fail-fast: false
services:
postgres:
image: postgres:13
env:
POSTGRES_DB: redmine
POSTGRES_USER: postgres
POSTGRES_PASSWORD: postgres
ports:
- 5432:5432
options: >-
--health-cmd pg_isready
--health-interval 10s
--health-timeout 5s
--health-retries 5
mysql:
image: mysql:8.0
env:
MYSQL_ROOT_PASSWORD: 'BestPasswordEver'
ports:
# will assign a random free host port
- 3306/tcp
options: >-
--health-cmd="mysqladmin ping"
--health-interval=10s
--health-timeout=5s
--health-retries=3
steps:
- name: Verify MySQL connection from host
run: |
mysql --host 127.0.0.1 --port ${{ job.services.mysql.ports[3306] }} -uroot -pBestPasswordEver -e "SHOW DATABASES"
if: matrix.db == 'mysql'
- name: Checkout Redmine
uses: actions/checkout@v2
with:
repository: redmine/redmine
ref: ${{ matrix.redmine }}
path: redmine
- name: Checkout additionals
uses: actions/checkout@v2
with:
repository: AlphaNodes/additionals
path: redmine/plugins/additionals
- name: Checkout redmine_hedgedoc
uses: actions/checkout@v2
with:
path: redmine/plugins/redmine_hedgedoc
- name: Update package archives
run: sudo apt-get update --yes --quiet
- name: Install package dependencies
run: >
sudo apt-get install --yes --quiet
build-essential
cmake
libicu-dev
libpq-dev
libmysqlclient-dev
- name: Setup Ruby
uses: ruby/setup-ruby@v1
with:
ruby-version: ${{ matrix.ruby }}
bundler-cache: true # runs 'bundle install' and caches installed gems automatically
- name: Prepare Redmine source
working-directory: redmine
run: |
sed -i '/rubocop/d' Gemfile
rm -f .rubocop*
cp plugins/redmine_hedgedoc/test/support/database-${{ matrix.db }}.yml config/database.yml
cp plugins/redmine_hedgedoc/test/support/configuration.yml config/configuration.yml
- name: Install Ruby dependencies
working-directory: redmine
run: |
bundle config set --local without 'development'
bundle install --jobs=4 --retry=3
- name: Generate session store secret
env:
RAILS_ENV: test
MYSQL_PORT: ${{ job.services.mysql.ports[3306] }}
working-directory: redmine
run: |
bundle exec rake generate_secret_token
- name: Run Redmine DB and migration tasks
env:
RAILS_ENV: test
MYSQL_PORT: ${{ job.services.mysql.ports[3306] }}
working-directory: redmine
run: |
bundle exec rake db:create:all
bundle exec rake db:migrate
- name: Import PostgreSQL dump with hedgedoc
working-directory: redmine
env:
PGPASSWORD: postgres
run: |
psql --host 127.0.0.1 --port 5432 -U postgres hedgedoc < plugins/redmine_hedgedoc/test/support/hedgedoc-postgres.sql
if: matrix.db == 'postgres'
- name: Import MySQL dump with hedgedoc
working-directory: redmine
run: |
mysql --host 127.0.0.1 --port ${{ job.services.mysql.ports[3306] }} -uroot -pBestPasswordEver hedgedoc < plugins/redmine_hedgedoc/test/support/hedgedoc-mysql.sql
if: matrix.db == 'mysql'
- name: Run tests
env:
RAILS_ENV: test
MYSQL_PORT: ${{ job.services.mysql.ports[3306] }}
working-directory: redmine
run: bundle exec rake redmine:plugins:test NAME=redmine_hedgedoc RUBYOPT="-W0"