Merge branch 'develop' into refactor/notification_settings
[akkoma] / .gitlab-ci.yml
1 image: elixir:1.9.4
2
3 variables: &global_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: &global_cache_policy
11 key: ${CI_COMMIT_REF_SLUG}
12 paths:
13 - deps
14 - _build
15
16 stages:
17 - build
18 - test
19 - benchmark
20 - deploy
21 - release
22 - docker
23
24 before_script:
25 - mix local.hex --force
26 - mix local.rebar --force
27
28 build:
29 stage: build
30 script:
31 - mix deps.get
32 - mix compile --force
33
34 benchmark:
35 stage: benchmark
36 when: manual
37 variables:
38 MIX_ENV: benchmark
39 services:
40 - name: postgres:9.6
41 alias: postgres
42 command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
43 script:
44 - mix deps.get
45 - mix ecto.create
46 - mix ecto.migrate
47 - mix pleroma.load_testing
48
49 unit-testing:
50 stage: test
51 retry: 2
52 cache: &testing_cache_policy
53 <<: *global_cache_policy
54 policy: pull
55
56 services:
57 - name: postgres:9.6
58 alias: postgres
59 command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
60 script:
61 - apt-get update && apt-get install -y libimage-exiftool-perl
62 - mix deps.get
63 - mix ecto.create
64 - mix ecto.migrate
65 - mix coveralls --preload-modules
66
67 federated-testing:
68 stage: test
69 cache: *testing_cache_policy
70 services:
71 - name: minibikini/postgres-with-rum:12
72 alias: postgres
73 command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
74 script:
75 - mix deps.get
76 - mix ecto.create
77 - mix ecto.migrate
78 - epmd -daemon
79 - mix test --trace --only federated
80
81 unit-testing-rum:
82 stage: test
83 retry: 2
84 cache: *testing_cache_policy
85 services:
86 - name: minibikini/postgres-with-rum:12
87 alias: postgres
88 command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
89 variables:
90 <<: *global_variables
91 RUM_ENABLED: "true"
92 script:
93 - apt-get update && apt-get install -y libimage-exiftool-perl
94 - mix deps.get
95 - mix ecto.create
96 - mix ecto.migrate
97 - "mix ecto.migrate --migrations-path priv/repo/optional_migrations/rum_indexing/"
98 - mix test --preload-modules
99
100 lint:
101 stage: test
102 cache: *testing_cache_policy
103 script:
104 - mix format --check-formatted
105
106 analysis:
107 stage: test
108 cache: *testing_cache_policy
109 script:
110 - mix deps.get
111 - mix credo --strict --only=warnings,todo,fixme,consistency,readability
112
113 docs-deploy:
114 stage: deploy
115 cache: *testing_cache_policy
116 image: alpine:latest
117 only:
118 - stable@pleroma/pleroma
119 - develop@pleroma/pleroma
120 before_script:
121 - apk add curl
122 script:
123 - 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
124 review_app:
125 image: alpine:3.9
126 stage: deploy
127 before_script:
128 - apk update && apk add openssh-client git
129 when: manual
130 environment:
131 name: review/$CI_COMMIT_REF_NAME
132 url: https://$CI_ENVIRONMENT_SLUG.pleroma.online/
133 on_stop: stop_review_app
134 only:
135 - branches
136 except:
137 - master
138 - develop
139 script:
140 - echo "$CI_ENVIRONMENT_SLUG"
141 - mkdir -p ~/.ssh
142 - eval $(ssh-agent -s)
143 - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add -
144 - ssh-keyscan -H "pleroma.online" >> ~/.ssh/known_hosts
145 - (ssh -t dokku@pleroma.online -- apps:create "$CI_ENVIRONMENT_SLUG") || true
146 - (ssh -t dokku@pleroma.online -- git:set "$CI_ENVIRONMENT_SLUG" keep-git-dir true) || true
147 - 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
148 - (ssh -t dokku@pleroma.online -- postgres:create $(echo $CI_ENVIRONMENT_SLUG | sed -e 's/-/_/g')_db) || true
149 - (ssh -t dokku@pleroma.online -- postgres:link $(echo $CI_ENVIRONMENT_SLUG | sed -e 's/-/_/g')_db "$CI_ENVIRONMENT_SLUG") || true
150 - (ssh -t dokku@pleroma.online -- certs:add "$CI_ENVIRONMENT_SLUG" /home/dokku/server.crt /home/dokku/server.key) || true
151 - git push -f dokku@pleroma.online:$CI_ENVIRONMENT_SLUG $CI_COMMIT_SHA:refs/heads/master
152
153 stop_review_app:
154 image: alpine:3.9
155 stage: deploy
156 before_script:
157 - apk update && apk add openssh-client git
158 when: manual
159 environment:
160 name: review/$CI_COMMIT_REF_NAME
161 action: stop
162 script:
163 - echo "$CI_ENVIRONMENT_SLUG"
164 - mkdir -p ~/.ssh
165 - eval $(ssh-agent -s)
166 - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add -
167 - ssh-keyscan -H "pleroma.online" >> ~/.ssh/known_hosts
168 - ssh -t dokku@pleroma.online -- --force apps:destroy "$CI_ENVIRONMENT_SLUG"
169 - ssh -t dokku@pleroma.online -- --force postgres:destroy $(echo $CI_ENVIRONMENT_SLUG | sed -e 's/-/_/g')_db
170
171 amd64:
172 stage: release
173 image: elixir:1.10.3
174 only: &release-only
175 - stable@pleroma/pleroma
176 - develop@pleroma/pleroma
177 - /^maint/.*$/@pleroma/pleroma
178 - /^release/.*$/@pleroma/pleroma
179 artifacts: &release-artifacts
180 name: "pleroma-$CI_COMMIT_REF_NAME-$CI_COMMIT_SHORT_SHA-$CI_JOB_NAME"
181 paths:
182 - release/*
183 # Ideally it would be never for master branch and with the next commit for develop,
184 # but Gitlab does not support neither `only` for artifacts
185 # nor setting it to never from .gitlab-ci.yml
186 # nor expiring with the next commit
187 expire_in: 42 yrs
188
189 cache: &release-cache
190 key: $CI_COMMIT_REF_NAME-$CI_JOB_NAME
191 paths:
192 - deps
193 variables: &release-variables
194 MIX_ENV: prod
195 before_script: &before-release
196 - echo "import Mix.Config" > config/prod.secret.exs
197 - mix local.hex --force
198 - mix local.rebar --force
199 script: &release
200 - mix deps.get --only prod
201 - mkdir release
202 - export PLEROMA_BUILD_BRANCH=$CI_COMMIT_REF_NAME
203 - mix release --path release
204
205
206 amd64-musl:
207 stage: release
208 artifacts: *release-artifacts
209 only: *release-only
210 image: elixir:1.10.3-alpine
211 cache: *release-cache
212 variables: *release-variables
213 before_script: &before-release-musl
214 - apk add git gcc g++ musl-dev make
215 - echo "import Mix.Config" > config/prod.secret.exs
216 - mix local.hex --force
217 - mix local.rebar --force
218 script: *release
219
220 arm:
221 stage: release
222 artifacts: *release-artifacts
223 only: *release-only
224 tags:
225 - arm32
226 image: elixir:1.10.3
227 cache: *release-cache
228 variables: *release-variables
229 before_script: *before-release
230 script: *release
231
232 arm-musl:
233 stage: release
234 artifacts: *release-artifacts
235 only: *release-only
236 tags:
237 - arm32
238 image: elixir:1.10.3-alpine
239 cache: *release-cache
240 variables: *release-variables
241 before_script: *before-release-musl
242 script: *release
243
244 arm64:
245 stage: release
246 artifacts: *release-artifacts
247 only: *release-only
248 tags:
249 - arm
250 image: elixir:1.10.3
251 cache: *release-cache
252 variables: *release-variables
253 before_script: *before-release
254 script: *release
255
256 arm64-musl:
257 stage: release
258 artifacts: *release-artifacts
259 only: *release-only
260 tags:
261 - arm
262 # TODO: Replace with upstream image when 1.9.0 comes out
263 image: elixir:1.10.3-alpine
264 cache: *release-cache
265 variables: *release-variables
266 before_script: *before-release-musl
267 script: *release
268
269 docker:
270 stage: docker
271 image: docker:latest
272 cache: {}
273 dependencies: []
274 variables: &docker-variables
275 DOCKER_DRIVER: overlay2
276 DOCKER_HOST: unix:///var/run/docker.sock
277 IMAGE_TAG: $CI_REGISTRY_IMAGE:$CI_COMMIT_SHORT_SHA
278 IMAGE_TAG_SLUG: $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
279 IMAGE_TAG_LATEST: $CI_REGISTRY_IMAGE:latest
280 IMAGE_TAG_LATEST_STABLE: $CI_REGISTRY_IMAGE:latest-stable
281 before_script: &before-docker
282 - docker login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY
283 - docker pull $IMAGE_TAG_SLUG || true
284 - export CI_JOB_TIMESTAMP=$(date --utc -Iseconds)
285 - export CI_VCS_REF=$CI_COMMIT_SHORT_SHA
286 allow_failure: true
287 script:
288 - docker build --cache-from $IMAGE_TAG_SLUG --build-arg VCS_REF=$CI_VCS_REF --build-arg BUILD_DATE=$CI_JOB_TIMESTAMP -t $IMAGE_TAG -t $IMAGE_TAG_SLUG -t $IMAGE_TAG_LATEST .
289 - docker push $IMAGE_TAG
290 - docker push $IMAGE_TAG_SLUG
291 - docker push $IMAGE_TAG_LATEST
292 tags:
293 - dind
294 only:
295 - develop@pleroma/pleroma
296
297 docker-stable:
298 stage: docker
299 image: docker:latest
300 cache: {}
301 dependencies: []
302 variables: *docker-variables
303 before_script: *before-docker
304 allow_failure: true
305 script:
306 - docker build --cache-from $IMAGE_TAG_SLUG --build-arg VCS_REF=$CI_VCS_REF --build-arg BUILD_DATE=$CI_JOB_TIMESTAMP -t $IMAGE_TAG -t $IMAGE_TAG_SLUG -t $IMAGE_TAG_LATEST_STABLE .
307 - docker push $IMAGE_TAG
308 - docker push $IMAGE_TAG_SLUG
309 - docker push $IMAGE_TAG_LATEST_STABLE
310 tags:
311 - dind
312 only:
313 - stable@pleroma/pleroma
314
315 docker-release:
316 stage: docker
317 image: docker:latest
318 cache: {}
319 dependencies: []
320 variables: *docker-variables
321 before_script: *before-docker
322 allow_failure: true
323 script:
324 - docker build --cache-from $IMAGE_TAG_SLUG --build-arg VCS_REF=$CI_VCS_REF --build-arg BUILD_DATE=$CI_JOB_TIMESTAMP -t $IMAGE_TAG -t $IMAGE_TAG_SLUG .
325 - docker push $IMAGE_TAG
326 - docker push $IMAGE_TAG_SLUG
327 tags:
328 - dind
329 only:
330 - /^release/.*$/@pleroma/pleroma