66fa806f86d1d6ecc62dce97973c20881d4d92a6
[akkoma] / .gitlab-ci.yml
1 image: elixir:1.8.1
2
3 variables:
4 POSTGRES_DB: pleroma_test
5 POSTGRES_USER: postgres
6 POSTGRES_PASSWORD: postgres
7 DB_HOST: postgres
8 MIX_ENV: test
9
10 cache:
11 key: ${CI_COMMIT_REF_SLUG}
12 paths:
13 - deps
14 - _build
15 stages:
16 - build
17 - test
18 - benchmark
19 - deploy
20 - release
21
22 before_script:
23 - mix local.hex --force
24 - mix local.rebar --force
25
26 build:
27 stage: build
28 script:
29 - mix deps.get
30 - mix compile --force
31
32 benchmark:
33 stage: benchmark
34 variables:
35 MIX_ENV: benchmark
36 services:
37 - name: postgres:9.6
38 alias: postgres
39 command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
40 script:
41 - mix deps.get
42 - mix ecto.create
43 - mix ecto.migrate
44 - mix pleroma.load_testing
45
46 unit-testing:
47 stage: test
48 services:
49 - name: postgres:9.6
50 alias: postgres
51 command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
52 script:
53 - mix deps.get
54 - mix ecto.create
55 - mix ecto.migrate
56 - mix coveralls --preload-modules
57
58 federated-testing:
59 stage: test
60 services:
61 - name: lainsoykaf/postgres-with-rum
62 alias: postgres
63 command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
64 script:
65 - mix deps.get
66 - mix ecto.create
67 - mix ecto.migrate
68 - epmd -daemon
69 - mix test --trace --only federated
70
71 unit-testing-rum:
72 stage: test
73 services:
74 - name: minibikini/postgres-with-rum:12
75 alias: postgres
76 command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
77 variables:
78 RUM_ENABLED: "true"
79 script:
80 - mix deps.get
81 - mix ecto.create
82 - mix ecto.migrate
83 - "mix ecto.migrate --migrations-path priv/repo/optional_migrations/rum_indexing/"
84 - mix test --preload-modules
85
86 lint:
87 stage: test
88 script:
89 - mix format --check-formatted
90
91 analysis:
92 stage: test
93 script:
94 - mix deps.get
95 - mix credo --strict --only=warnings,todo,fixme,consistency,readability
96
97 docs-deploy:
98 stage: deploy
99 image: alpine:latest
100 only:
101 - stable@pleroma/pleroma
102 - develop@pleroma/pleroma
103 before_script:
104 - apk add curl
105 script:
106 - curl -X POST -F"token=$DOCS_PIPELINE_TRIGGER" -F'ref=master' -F"variables[BRANCH]=$CI_COMMIT_REF_NAME" https://git.pleroma.social/api/v4/projects/673/trigger/pipeline
107 review_app:
108 image: alpine:3.9
109 stage: deploy
110 before_script:
111 - apk update && apk add openssh-client git
112 when: manual
113 environment:
114 name: review/$CI_COMMIT_REF_NAME
115 url: https://$CI_ENVIRONMENT_SLUG.pleroma.online/
116 on_stop: stop_review_app
117 only:
118 - branches
119 except:
120 - master
121 - develop
122 script:
123 - echo "$CI_ENVIRONMENT_SLUG"
124 - mkdir -p ~/.ssh
125 - eval $(ssh-agent -s)
126 - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add -
127 - ssh-keyscan -H "pleroma.online" >> ~/.ssh/known_hosts
128 - (ssh -t dokku@pleroma.online -- apps:create "$CI_ENVIRONMENT_SLUG") || true
129 - (ssh -t dokku@pleroma.online -- git:set "$CI_ENVIRONMENT_SLUG" keep-git-dir true) || true
130 - ssh -t dokku@pleroma.online -- config:set "$CI_ENVIRONMENT_SLUG" APP_NAME="$CI_ENVIRONMENT_SLUG" APP_HOST="$CI_ENVIRONMENT_SLUG.pleroma.online" MIX_ENV=dokku
131 - (ssh -t dokku@pleroma.online -- postgres:create $(echo $CI_ENVIRONMENT_SLUG | sed -e 's/-/_/g')_db) || true
132 - (ssh -t dokku@pleroma.online -- postgres:link $(echo $CI_ENVIRONMENT_SLUG | sed -e 's/-/_/g')_db "$CI_ENVIRONMENT_SLUG") || true
133 - (ssh -t dokku@pleroma.online -- certs:add "$CI_ENVIRONMENT_SLUG" /home/dokku/server.crt /home/dokku/server.key) || true
134 - git push -f dokku@pleroma.online:$CI_ENVIRONMENT_SLUG $CI_COMMIT_SHA:refs/heads/master
135
136 stop_review_app:
137 image: alpine:3.9
138 stage: deploy
139 before_script:
140 - apk update && apk add openssh-client git
141 when: manual
142 environment:
143 name: review/$CI_COMMIT_REF_NAME
144 action: stop
145 script:
146 - echo "$CI_ENVIRONMENT_SLUG"
147 - mkdir -p ~/.ssh
148 - eval $(ssh-agent -s)
149 - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add -
150 - ssh-keyscan -H "pleroma.online" >> ~/.ssh/known_hosts
151 - ssh -t dokku@pleroma.online -- --force apps:destroy "$CI_ENVIRONMENT_SLUG"
152 - ssh -t dokku@pleroma.online -- --force postgres:destroy $(echo $CI_ENVIRONMENT_SLUG | sed -e 's/-/_/g')_db
153
154 amd64:
155 stage: release
156 # TODO: Replace with upstream image when 1.9.0 comes out
157 image: rinpatch/elixir:1.9.0-rc.0
158 only: &release-only
159 - stable@pleroma/pleroma
160 - develop@pleroma/pleroma
161 - /^maint/.*$/@pleroma/pleroma
162 - /^release/.*$/@pleroma/pleroma
163 artifacts: &release-artifacts
164 name: "pleroma-$CI_COMMIT_REF_NAME-$CI_COMMIT_SHORT_SHA-$CI_JOB_NAME"
165 paths:
166 - release/*
167 # Ideally it would be never for master branch and with the next commit for develop,
168 # but Gitlab does not support neither `only` for artifacts
169 # nor setting it to never from .gitlab-ci.yml
170 # nor expiring with the next commit
171 expire_in: 42 yrs
172
173 cache: &release-cache
174 key: $CI_COMMIT_REF_NAME-$CI_JOB_NAME
175 paths:
176 - deps
177 variables: &release-variables
178 MIX_ENV: prod
179 before_script: &before-release
180 - echo "import Mix.Config" > config/prod.secret.exs
181 - mix local.hex --force
182 - mix local.rebar --force
183 script: &release
184 - mix deps.get --only prod
185 - mkdir release
186 - export PLEROMA_BUILD_BRANCH=$CI_COMMIT_REF_NAME
187 - mix release --path release
188
189
190 amd64-musl:
191 stage: release
192 artifacts: *release-artifacts
193 only: *release-only
194 # TODO: Replace with upstream image when 1.9.0 comes out
195 image: rinpatch/elixir:1.9.0-rc.0-alpine
196 cache: *release-cache
197 variables: *release-variables
198 before_script: &before-release-musl
199 - apk add git gcc g++ musl-dev make
200 - echo "import Mix.Config" > config/prod.secret.exs
201 - mix local.hex --force
202 - mix local.rebar --force
203 script: *release
204
205 arm:
206 stage: release
207 artifacts: *release-artifacts
208 only: *release-only
209 tags:
210 - arm32
211 # TODO: Replace with upstream image when 1.9.0 comes out
212 image: rinpatch/elixir:1.9.0-rc.0-arm
213 cache: *release-cache
214 variables: *release-variables
215 before_script: *before-release
216 script: *release
217
218 arm-musl:
219 stage: release
220 artifacts: *release-artifacts
221 only: *release-only
222 tags:
223 - arm32
224 # TODO: Replace with upstream image when 1.9.0 comes out
225 image: rinpatch/elixir:1.9.0-rc.0-arm-alpine
226 cache: *release-cache
227 variables: *release-variables
228 before_script: *before-release-musl
229 script: *release
230
231 arm64:
232 stage: release
233 artifacts: *release-artifacts
234 only: *release-only
235 tags:
236 - arm
237 # TODO: Replace with upstream image when 1.9.0 comes out
238 image: rinpatch/elixir:1.9.0-rc.0-arm64
239 cache: *release-cache
240 variables: *release-variables
241 before_script: *before-release
242 script: *release
243
244 arm64-musl:
245 stage: release
246 artifacts: *release-artifacts
247 only: *release-only
248 tags:
249 - arm
250 # TODO: Replace with upstream image when 1.9.0 comes out
251 image: rinpatch/elixir:1.9.0-rc.0-arm64-alpine
252 cache: *release-cache
253 variables: *release-variables
254 before_script: *before-release-musl
255 script: *release