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