4 POSTGRES_DB: pleroma_test
5 POSTGRES_USER: postgres
6 POSTGRES_PASSWORD: postgres
11 key: ${CI_COMMIT_REF_SLUG}
23 - mix local.hex --force
24 - mix local.rebar --force
35 - master@pleroma/pleroma
36 - develop@pleroma/pleroma
39 PLEROMA_BUILD_ENV: prod
53 - name: lainsoykaf/postgres-with-rum
55 command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
60 - mix pleroma.benchmark
65 - name: lainsoykaf/postgres-with-rum
67 command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
72 - mix coveralls --trace --preload-modules
77 - name: lainsoykaf/postgres-with-rum
79 command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
86 - "mix ecto.migrate --migrations-path priv/repo/optional_migrations/rum_indexing/"
87 - mix test --trace --preload-modules
92 - mix format --check-formatted
98 - mix credo --strict --only=warnings,todo,fixme,consistency,readability
104 - master@pleroma/pleroma
105 - develop@pleroma/pleroma
107 - apk update && apk add openssh-client rsync
110 - echo "${SSH_HOST_KEY}" > ~/.ssh/known_hosts
111 - eval $(ssh-agent -s)
112 - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add -
113 - rsync -hrvz --delete -e "ssh -p ${SSH_PORT}" priv/static/doc/ "${SSH_USER_HOST_LOCATION}/${CI_COMMIT_REF_NAME}"
119 - apk update && apk add openssh-client git
122 name: review/$CI_COMMIT_REF_NAME
123 url: https://$CI_ENVIRONMENT_SLUG.pleroma.online/
124 on_stop: stop_review_app
131 - echo "$CI_ENVIRONMENT_SLUG"
133 - eval $(ssh-agent -s)
134 - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add -
135 - ssh-keyscan -H "pleroma.online" >> ~/.ssh/known_hosts
136 - (ssh -t dokku@pleroma.online -- apps:create "$CI_ENVIRONMENT_SLUG") || true
137 - 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
138 - (ssh -t dokku@pleroma.online -- postgres:create $(echo $CI_ENVIRONMENT_SLUG | sed -e 's/-/_/g')_db) || true
139 - (ssh -t dokku@pleroma.online -- postgres:link $(echo $CI_ENVIRONMENT_SLUG | sed -e 's/-/_/g')_db "$CI_ENVIRONMENT_SLUG") || true
140 - (ssh -t dokku@pleroma.online -- certs:add "$CI_ENVIRONMENT_SLUG" /home/dokku/server.crt /home/dokku/server.key) || true
141 - git push -f dokku@pleroma.online:$CI_ENVIRONMENT_SLUG $CI_COMMIT_SHA:refs/heads/master
147 - apk update && apk add openssh-client git
150 name: review/$CI_COMMIT_REF_NAME
153 - echo "$CI_ENVIRONMENT_SLUG"
155 - eval $(ssh-agent -s)
156 - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add -
157 - ssh-keyscan -H "pleroma.online" >> ~/.ssh/known_hosts
158 - ssh -t dokku@pleroma.online -- --force apps:destroy "$CI_ENVIRONMENT_SLUG"
159 - ssh -t dokku@pleroma.online -- --force postgres:destroy $(echo $CI_ENVIRONMENT_SLUG | sed -e 's/-/_/g')_db
163 # TODO: Replace with upstream image when 1.9.0 comes out
164 image: rinpatch/elixir:1.9.0-rc.0
166 - master@pleroma/pleroma
167 - develop@pleroma/pleroma
168 artifacts: &release-artifacts
169 name: "pleroma-$CI_COMMIT_REF_NAME-$CI_COMMIT_SHORT_SHA-$CI_JOB_NAME"
172 # Ideally it would be never for master branch and with the next commit for develop,
173 # but Gitlab does not support neither `only` for artifacts
174 # nor setting it to never from .gitlab-ci.yml
175 # nor expiring with the next commit
178 cache: &release-cache
179 key: $CI_COMMIT_REF_NAME-$CI_JOB_NAME
182 variables: &release-variables
184 before_script: &before-release
185 - echo "import Mix.Config" > config/prod.secret.exs
186 - mix local.hex --force
187 - mix local.rebar --force
189 - mix deps.get --only prod
191 - export PLEROMA_BUILD_BRANCH=$CI_COMMIT_REF_NAME
192 - mix release --path release
197 artifacts: *release-artifacts
199 # TODO: Replace with upstream image when 1.9.0 comes out
200 image: rinpatch/elixir:1.9.0-rc.0-alpine
201 cache: *release-cache
202 variables: *release-variables
203 before_script: &before-release-musl
204 - apk add git gcc g++ musl-dev make
205 - echo "import Mix.Config" > config/prod.secret.exs
206 - mix local.hex --force
207 - mix local.rebar --force
212 artifacts: *release-artifacts
216 # TODO: Replace with upstream image when 1.9.0 comes out
217 image: rinpatch/elixir:1.9.0-rc.0-arm
218 cache: *release-cache
219 variables: *release-variables
220 before_script: *before-release
225 artifacts: *release-artifacts
229 # TODO: Replace with upstream image when 1.9.0 comes out
230 image: rinpatch/elixir:1.9.0-rc.0-arm-alpine
231 cache: *release-cache
232 variables: *release-variables
233 before_script: *before-release-musl
238 artifacts: *release-artifacts
242 # TODO: Replace with upstream image when 1.9.0 comes out
243 image: rinpatch/elixir:1.9.0-rc.0-arm64
244 cache: *release-cache
245 variables: *release-variables
246 before_script: *before-release
251 artifacts: *release-artifacts
255 # TODO: Replace with upstream image when 1.9.0 comes out
256 image: rinpatch/elixir:1.9.0-rc.0-arm64-alpine
257 cache: *release-cache
258 variables: *release-variables
259 before_script: *before-release-musl