Fork of Pleroma with site-specific changes and feature branches https://git.pleroma.social/pleroma/pleroma
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

396 lines
12KB

  1. image: elixir:1.9.4
  2. variables: &global_variables
  3. POSTGRES_DB: pleroma_test
  4. POSTGRES_USER: postgres
  5. POSTGRES_PASSWORD: postgres
  6. DB_HOST: postgres
  7. MIX_ENV: test
  8. cache: &global_cache_policy
  9. key: ${CI_COMMIT_REF_SLUG}
  10. paths:
  11. - deps
  12. - _build
  13. stages:
  14. - build
  15. - test
  16. - benchmark
  17. - deploy
  18. - release
  19. - docker
  20. before_script:
  21. - apt-get update && apt-get install -y cmake
  22. - mix local.hex --force
  23. - mix local.rebar --force
  24. - apt-get -qq update
  25. - apt-get install -y libmagic-dev
  26. build:
  27. stage: build
  28. script:
  29. - mix deps.get
  30. - mix compile --force
  31. spec-build:
  32. stage: test
  33. artifacts:
  34. paths:
  35. - spec.json
  36. script:
  37. - mix pleroma.openapi_spec spec.json
  38. benchmark:
  39. stage: benchmark
  40. when: manual
  41. variables:
  42. MIX_ENV: benchmark
  43. services:
  44. - name: postgres:9.6
  45. alias: postgres
  46. command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
  47. script:
  48. - mix deps.get
  49. - mix ecto.create
  50. - mix ecto.migrate
  51. - mix pleroma.load_testing
  52. unit-testing:
  53. stage: test
  54. retry: 2
  55. cache: &testing_cache_policy
  56. <<: *global_cache_policy
  57. policy: pull
  58. services:
  59. - name: postgres:13
  60. alias: postgres
  61. command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
  62. script:
  63. - apt-get update && apt-get install -y libimage-exiftool-perl ffmpeg
  64. - mix deps.get
  65. - mix ecto.create
  66. - mix ecto.migrate
  67. - mix coveralls --preload-modules
  68. # Removed to fix CI issue. In this early state it wasn't adding much value anyway.
  69. # TODO Fix and reinstate federated testing
  70. # federated-testing:
  71. # stage: test
  72. # cache: *testing_cache_policy
  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. # script:
  78. # - mix deps.get
  79. # - mix ecto.create
  80. # - mix ecto.migrate
  81. # - epmd -daemon
  82. # - mix test --trace --only federated
  83. unit-testing-rum:
  84. stage: test
  85. retry: 2
  86. cache: *testing_cache_policy
  87. services:
  88. - name: minibikini/postgres-with-rum:12
  89. alias: postgres
  90. command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
  91. variables:
  92. <<: *global_variables
  93. RUM_ENABLED: "true"
  94. script:
  95. - apt-get update && apt-get install -y libimage-exiftool-perl ffmpeg
  96. - mix deps.get
  97. - mix ecto.create
  98. - mix ecto.migrate
  99. - "mix ecto.migrate --migrations-path priv/repo/optional_migrations/rum_indexing/"
  100. - mix test --preload-modules
  101. lint:
  102. stage: test
  103. cache: *testing_cache_policy
  104. script:
  105. - mix format --check-formatted
  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. docs-deploy:
  113. stage: deploy
  114. cache: *testing_cache_policy
  115. image: alpine:latest
  116. only:
  117. - stable@pleroma/pleroma
  118. - develop@pleroma/pleroma
  119. before_script:
  120. - apk add curl
  121. script:
  122. - 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
  123. review_app:
  124. image: alpine:3.9
  125. stage: deploy
  126. before_script:
  127. - apk update && apk add openssh-client git
  128. when: manual
  129. environment:
  130. name: review/$CI_COMMIT_REF_NAME
  131. url: https://$CI_ENVIRONMENT_SLUG.pleroma.online/
  132. on_stop: stop_review_app
  133. only:
  134. - branches
  135. except:
  136. - master
  137. - develop
  138. script:
  139. - echo "$CI_ENVIRONMENT_SLUG"
  140. - mkdir -p ~/.ssh
  141. - eval $(ssh-agent -s)
  142. - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add -
  143. - ssh-keyscan -H "pleroma.online" >> ~/.ssh/known_hosts
  144. - (ssh -t dokku@pleroma.online -- apps:create "$CI_ENVIRONMENT_SLUG") || true
  145. - (ssh -t dokku@pleroma.online -- git:set "$CI_ENVIRONMENT_SLUG" keep-git-dir true) || true
  146. - 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
  147. - (ssh -t dokku@pleroma.online -- postgres:create $(echo $CI_ENVIRONMENT_SLUG | sed -e 's/-/_/g')_db) || true
  148. - (ssh -t dokku@pleroma.online -- postgres:link $(echo $CI_ENVIRONMENT_SLUG | sed -e 's/-/_/g')_db "$CI_ENVIRONMENT_SLUG") || true
  149. - (ssh -t dokku@pleroma.online -- certs:add "$CI_ENVIRONMENT_SLUG" /home/dokku/server.crt /home/dokku/server.key) || true
  150. - git push -f dokku@pleroma.online:$CI_ENVIRONMENT_SLUG $CI_COMMIT_SHA:refs/heads/master
  151. spec-deploy:
  152. stage: deploy
  153. artifacts:
  154. paths:
  155. - spec.json
  156. only:
  157. - develop@pleroma/pleroma
  158. image: alpine:latest
  159. before_script:
  160. - apk add curl
  161. script:
  162. - curl -X POST -F"token=$API_DOCS_PIPELINE_TRIGGER" -F'ref=master' -F"variables[BRANCH]=$CI_COMMIT_REF_NAME" -F"variables[JOB_REF]=$CI_JOB_ID" https://git.pleroma.social/api/v4/projects/1130/trigger/pipeline
  163. stop_review_app:
  164. image: alpine:3.9
  165. stage: deploy
  166. before_script:
  167. - apk update && apk add openssh-client git
  168. when: manual
  169. environment:
  170. name: review/$CI_COMMIT_REF_NAME
  171. action: stop
  172. script:
  173. - echo "$CI_ENVIRONMENT_SLUG"
  174. - mkdir -p ~/.ssh
  175. - eval $(ssh-agent -s)
  176. - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add -
  177. - ssh-keyscan -H "pleroma.online" >> ~/.ssh/known_hosts
  178. - ssh -t dokku@pleroma.online -- --force apps:destroy "$CI_ENVIRONMENT_SLUG"
  179. - ssh -t dokku@pleroma.online -- --force postgres:destroy $(echo $CI_ENVIRONMENT_SLUG | sed -e 's/-/_/g')_db
  180. amd64:
  181. stage: release
  182. image: elixir:1.10.3
  183. only: &release-only
  184. - stable@pleroma/pleroma
  185. - develop@pleroma/pleroma
  186. - /^maint/.*$/@pleroma/pleroma
  187. - /^release/.*$/@pleroma/pleroma
  188. artifacts: &release-artifacts
  189. name: "pleroma-$CI_COMMIT_REF_NAME-$CI_COMMIT_SHORT_SHA-$CI_JOB_NAME"
  190. paths:
  191. - release/*
  192. # Ideally it would be never for master branch and with the next commit for develop,
  193. # but Gitlab does not support neither `only` for artifacts
  194. # nor setting it to never from .gitlab-ci.yml
  195. # nor expiring with the next commit
  196. expire_in: 42 yrs
  197. cache: &release-cache
  198. key: $CI_COMMIT_REF_NAME-$CI_JOB_NAME
  199. paths:
  200. - deps
  201. variables: &release-variables
  202. MIX_ENV: prod
  203. before_script: &before-release
  204. - apt-get update && apt-get install -y cmake libmagic-dev
  205. - echo "import Mix.Config" > config/prod.secret.exs
  206. - mix local.hex --force
  207. - mix local.rebar --force
  208. script: &release
  209. - mix deps.get --only prod
  210. - mkdir release
  211. - export PLEROMA_BUILD_BRANCH=$CI_COMMIT_REF_NAME
  212. - mix release --path release
  213. amd64-musl:
  214. stage: release
  215. artifacts: *release-artifacts
  216. only: *release-only
  217. image: elixir:1.10.3-alpine
  218. cache: *release-cache
  219. variables: *release-variables
  220. before_script: &before-release-musl
  221. - apk add git gcc g++ musl-dev make cmake file-dev
  222. - echo "import Mix.Config" > config/prod.secret.exs
  223. - mix local.hex --force
  224. - mix local.rebar --force
  225. script: *release
  226. arm:
  227. stage: release
  228. artifacts: *release-artifacts
  229. only: *release-only
  230. tags:
  231. - arm32-specified
  232. image: arm32v7/elixir:1.10.3
  233. cache: *release-cache
  234. variables: *release-variables
  235. before_script: *before-release
  236. script: *release
  237. arm-musl:
  238. stage: release
  239. artifacts: *release-artifacts
  240. only: *release-only
  241. tags:
  242. - arm32-specified
  243. image: arm32v7/elixir:1.10.3-alpine
  244. cache: *release-cache
  245. variables: *release-variables
  246. before_script: *before-release-musl
  247. script: *release
  248. arm64:
  249. stage: release
  250. artifacts: *release-artifacts
  251. only: *release-only
  252. tags:
  253. - arm
  254. image: arm64v8/elixir:1.10.3
  255. cache: *release-cache
  256. variables: *release-variables
  257. before_script: *before-release
  258. script: *release
  259. arm64-musl:
  260. stage: release
  261. artifacts: *release-artifacts
  262. only: *release-only
  263. tags:
  264. - arm
  265. image: arm64v8/elixir:1.10.3-alpine
  266. cache: *release-cache
  267. variables: *release-variables
  268. before_script: *before-release-musl
  269. script: *release
  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. DOCKER_BUILDX_URL: https://github.com/docker/buildx/releases/download/v0.4.1/buildx-v0.4.1.linux-amd64
  283. DOCKER_BUILDX_HASH: 71a7d01439aa8c165a25b59c44d3f016fddbd98b
  284. before_script: &before-docker
  285. - docker login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY
  286. - docker pull $IMAGE_TAG_SLUG || true
  287. - export CI_JOB_TIMESTAMP=$(date --utc -Iseconds)
  288. - export CI_VCS_REF=$CI_COMMIT_SHORT_SHA
  289. allow_failure: true
  290. script:
  291. - mkdir -p /root/.docker/cli-plugins
  292. - wget "${DOCKER_BUILDX_URL}" -O ~/.docker/cli-plugins/docker-buildx
  293. - echo "${DOCKER_BUILDX_HASH} /root/.docker/cli-plugins/docker-buildx" | sha1sum -c
  294. - chmod +x ~/.docker/cli-plugins/docker-buildx
  295. - docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
  296. - docker buildx create --name mbuilder --driver docker-container --use
  297. - docker buildx inspect --bootstrap
  298. - docker buildx build --platform linux/amd64,linux/arm/v7,linux/arm64/v8 --push --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 .
  299. tags:
  300. - dind
  301. only:
  302. - develop@pleroma/pleroma
  303. docker-stable:
  304. stage: docker
  305. image: docker:latest
  306. cache: {}
  307. dependencies: []
  308. variables: *docker-variables
  309. before_script: *before-docker
  310. allow_failure: true
  311. script:
  312. - mkdir -p /root/.docker/cli-plugins
  313. - wget "${DOCKER_BUILDX_URL}" -O ~/.docker/cli-plugins/docker-buildx
  314. - echo "${DOCKER_BUILDX_HASH} /root/.docker/cli-plugins/docker-buildx" | sha1sum -c
  315. - chmod +x ~/.docker/cli-plugins/docker-buildx
  316. - docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
  317. - docker buildx create --name mbuilder --driver docker-container --use
  318. - docker buildx inspect --bootstrap
  319. - docker buildx build --platform linux/amd64,linux/arm/v7,linux/arm64/v8 --push --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 .
  320. tags:
  321. - dind
  322. only:
  323. - stable@pleroma/pleroma
  324. docker-release:
  325. stage: docker
  326. image: docker:latest
  327. cache: {}
  328. dependencies: []
  329. variables: *docker-variables
  330. before_script: *before-docker
  331. allow_failure: true
  332. script:
  333. script:
  334. - mkdir -p /root/.docker/cli-plugins
  335. - wget "${DOCKER_BUILDX_URL}" -O ~/.docker/cli-plugins/docker-buildx
  336. - echo "${DOCKER_BUILDX_HASH} /root/.docker/cli-plugins/docker-buildx" | sha1sum -c
  337. - chmod +x ~/.docker/cli-plugins/docker-buildx
  338. - docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
  339. - docker buildx create --name mbuilder --driver docker-container --use
  340. - docker buildx inspect --bootstrap
  341. - docker buildx build --platform linux/amd64,linux/arm/v7,linux/arm64/v8 --push --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 .
  342. tags:
  343. - dind
  344. only:
  345. - /^release/.*$/@pleroma/pleroma
  346. docker-adhoc:
  347. stage: docker
  348. image: docker:latest
  349. cache: {}
  350. dependencies: []
  351. variables: *docker-variables
  352. before_script: *before-docker
  353. allow_failure: true
  354. script:
  355. script:
  356. - mkdir -p /root/.docker/cli-plugins
  357. - wget "${DOCKER_BUILDX_URL}" -O ~/.docker/cli-plugins/docker-buildx
  358. - echo "${DOCKER_BUILDX_HASH} /root/.docker/cli-plugins/docker-buildx" | sha1sum -c
  359. - chmod +x ~/.docker/cli-plugins/docker-buildx
  360. - docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
  361. - docker buildx create --name mbuilder --driver docker-container --use
  362. - docker buildx inspect --bootstrap
  363. - docker buildx build --platform linux/amd64,linux/arm/v7,linux/arm64/v8 --push --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 .
  364. tags:
  365. - dind
  366. only:
  367. - /^build-docker/.*$/@pleroma/pleroma