-
Notifications
You must be signed in to change notification settings - Fork 2
119 lines (116 loc) · 4.16 KB
/
main.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
name: CI
on: [push, pull_request]
env:
RAILS_MASTER_KEY: ${{ secrets.RAILS_MASTER_KEY }}
DB_HOST: localhost
DB_USERNAME: postgres
DB_PASSWORD: postgres
jobs:
test:
runs-on: ubuntu-latest
services:
postgres:
image: postgres:14
env:
POSTGRES_DB: makerspacerepo_test
POSTGRES_PASSWORD: postgres
POSTGRES_USER: postgres
ports:
- 5432:5432
options: >-
--health-cmd pg_isready
--health-interval 10s
--health-timeout 5s
--health-retries 5
redis:
image: redis
ports: ["6379:6379"]
options: --entrypoint redis-server
steps:
- uses: actions/checkout@v3
- name: Setup Ruby
uses: ruby/setup-ruby@v1
with:
ruby-version: 3.1.2
bundler-cache: true
- uses: actions/setup-node@v3
with:
node-version: "18.12.1"
cache: "yarn"
- uses: actions/setup-python@v4
with:
python-version: 3.11
- name: Run Yarn install
uses: borales/actions-yarn@v4
with:
cmd: install
- name: Create Credentials File
id: create-json
uses: jsdaniell/[email protected]
with:
name: "makerepo-1632742c49cc.json"
json: ${{ secrets.CREDENTIALS_JSON }}
dir: "config/"
- name: Prepare Test
env:
DATABASE_URL: postgres://postgres:@localhost:5432/makerspacerepo_test
REDIS_URL: redis://localhost:6379/0
RAILS_ENV: test
run: |
sudo apt-get update
sudo apt-get -yqq install libpq-dev imagemagick
mkdir certs && touch certs/saml.key && touch certs/saml.crt
openssl req -x509 -newkey rsa:4096 -keyout certs/saml.key -out certs/saml.crt -days 1 -nodes -subj "/C=CA/ST=Ontario/L=Ottawa/O=uOttawa/OU=Richard L'Abbé Makerspace/CN=makerepo.com/[email protected]"
wget https://github.com/wkhtmltopdf/packaging/releases/download/0.12.6.1-2/wkhtmltox_0.12.6.1-2.jammy_amd64.deb
sudo apt install ./wkhtmltox_0.12.6.1-2.jammy_amd64.deb
- name: Migrate DB
env:
DATABASE_URL: postgres://postgres:@localhost:5432/makerspacerepo_test
REDIS_URL: redis://localhost:6379/0
RAILS_ENV: test
run: |
bundle exec rails db:prepare
bundle exec rails db:migrate
- name: Run tests
env:
DATABASE_URL: postgres://postgres:@localhost:5432/makerspacerepo_test
REDIS_URL: redis://localhost:6379/0
RAILS_ENV: test
run: |
bundle exec rails spec
- name: Deploy Staging
if: github.ref == 'refs/heads/staging'
env:
DEPLOY_ENC_KEY: ${{ secrets.DEPLOY_ENC_KEY }}
run: |
openssl enc -d -aes-256-cbc -md sha512 -salt -in config/deploy_id_ed25519_staging_enc -out config/deploy_id_ed25519_staging -k $DEPLOY_ENC_KEY -a -pbkdf2
chmod 600 config/deploy_id_ed25519_staging
eval "$(ssh-agent -s)"
ssh-add config/deploy_id_ed25519_staging
gem install capistrano
bundle exec cap staging deploy
- name: Deploy Master
if: github.ref == 'refs/heads/master'
env:
DEPLOY_ENC_KEY: ${{ secrets.DEPLOY_ENC_KEY }}
run: |
openssl enc -d -aes-256-cbc -md sha512 -salt -in config/deploy_id_ed25519_prod_enc -out config/deploy_id_ed25519_prod -k $DEPLOY_ENC_KEY -a -pbkdf2
chmod 600 config/deploy_id_ed25519_prod
eval "$(ssh-agent -s)"
ssh-add config/deploy_id_ed25519_prod
gem install capistrano
bundle exec cap production deploy
- uses: ravsamhq/notify-slack-action@master
if: always()
with:
status: ${{ job.status }}
notify_when: "success,failure,warnings"
env:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}
- uses: toko-bifrost/ms-teams-deploy-card@master
if: always()
with:
github-token: ${{ github.token }}
webhook-uri: ${{ secrets.MS_TEAMS_WEBHOOK_URI }}
timezone: "America/Montreal"
show-on-start: false