Fork of Pleroma with site-specific changes and feature branches https://git.pleroma.social/pleroma/pleroma
Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

399 строки
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:
  10. files:
  11. - mix.lock
  12. paths:
  13. - deps
  14. - _build
  15. stages:
  16. - build
  17. - test
  18. - benchmark
  19. - deploy
  20. - release
  21. - docker
  22. before_script:
  23. - rm -rf _build/*/lib/pleroma
  24. - apt-get update && apt-get install -y cmake
  25. - mix local.hex --force
  26. - mix local.rebar --force
  27. - mix deps.get
  28. - apt-get -qq update
  29. - apt-get install -y libmagic-dev
  30. after_script:
  31. - rm -rf _build/*/lib/pleroma
  32. build:
  33. stage: build
  34. script:
  35. - mix compile --force
  36. spec-build:
  37. stage: test
  38. artifacts:
  39. paths:
  40. - spec.json
  41. script:
  42. - mix pleroma.openapi_spec spec.json
  43. benchmark:
  44. stage: benchmark
  45. when: manual
  46. variables:
  47. MIX_ENV: benchmark
  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 ecto.create
  54. - mix ecto.migrate
  55. - mix pleroma.load_testing
  56. unit-testing:
  57. stage: test
  58. retry: 2
  59. cache: &testing_cache_policy
  60. <<: *global_cache_policy
  61. policy: pull
  62. services:
  63. - name: postgres:13
  64. alias: postgres
  65. command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
  66. script:
  67. - apt-get update && apt-get install -y libimage-exiftool-perl ffmpeg
  68. - mix ecto.create
  69. - mix ecto.migrate
  70. - mix coveralls --preload-modules
  71. # Removed to fix CI issue. In this early state it wasn't adding much value anyway.
  72. # TODO Fix and reinstate federated testing
  73. # federated-testing:
  74. # stage: test
  75. # cache: *testing_cache_policy
  76. # services:
  77. # - name: minibikini/postgres-with-rum:12
  78. # alias: postgres
  79. # command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
  80. # script:
  81. # - mix deps.get
  82. # - mix ecto.create
  83. # - mix ecto.migrate
  84. # - epmd -daemon
  85. # - mix test --trace --only federated
  86. unit-testing-rum:
  87. stage: test
  88. retry: 2
  89. cache: *testing_cache_policy
  90. services:
  91. - name: minibikini/postgres-with-rum:12
  92. alias: postgres
  93. command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
  94. variables:
  95. <<: *global_variables
  96. RUM_ENABLED: "true"
  97. script:
  98. - apt-get update && apt-get install -y libimage-exiftool-perl ffmpeg
  99. - mix ecto.create
  100. - mix ecto.migrate
  101. - "mix ecto.migrate --migrations-path priv/repo/optional_migrations/rum_indexing/"
  102. - mix test --preload-modules
  103. lint:
  104. stage: test
  105. cache: *testing_cache_policy
  106. script:
  107. - mix format --check-formatted
  108. analysis:
  109. stage: test
  110. cache: *testing_cache_policy
  111. script:
  112. - mix credo --strict --only=warnings,todo,fixme,consistency,readability
  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. spec-deploy:
  153. stage: deploy
  154. artifacts:
  155. paths:
  156. - spec.json
  157. only:
  158. - develop@pleroma/pleroma
  159. image: alpine:latest
  160. before_script:
  161. - apk add curl
  162. script:
  163. - 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
  164. stop_review_app:
  165. image: alpine:3.9
  166. stage: deploy
  167. before_script:
  168. - apk update && apk add openssh-client git
  169. when: manual
  170. environment:
  171. name: review/$CI_COMMIT_REF_NAME
  172. action: stop
  173. script:
  174. - echo "$CI_ENVIRONMENT_SLUG"
  175. - mkdir -p ~/.ssh
  176. - eval $(ssh-agent -s)
  177. - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add -
  178. - ssh-keyscan -H "pleroma.online" >> ~/.ssh/known_hosts
  179. - ssh -t dokku@pleroma.online -- --force apps:destroy "$CI_ENVIRONMENT_SLUG"
  180. - ssh -t dokku@pleroma.online -- --force postgres:destroy $(echo $CI_ENVIRONMENT_SLUG | sed -e 's/-/_/g')_db
  181. amd64:
  182. stage: release
  183. image: elixir:1.10.3
  184. only: &release-only
  185. - stable@pleroma/pleroma
  186. - develop@pleroma/pleroma
  187. - /^maint/.*$/@pleroma/pleroma
  188. - /^release/.*$/@pleroma/pleroma
  189. artifacts: &release-artifacts
  190. name: "pleroma-$CI_COMMIT_REF_NAME-$CI_COMMIT_SHORT_SHA-$CI_JOB_NAME"
  191. paths:
  192. - release/*
  193. # Ideally it would be never for master branch and with the next commit for develop,
  194. # but Gitlab does not support neither `only` for artifacts
  195. # nor setting it to never from .gitlab-ci.yml
  196. # nor expiring with the next commit
  197. expire_in: 42 yrs
  198. cache: &release-cache
  199. key: $CI_COMMIT_REF_NAME-$CI_JOB_NAME
  200. paths:
  201. - deps
  202. variables: &release-variables
  203. MIX_ENV: prod
  204. before_script: &before-release
  205. - apt-get update && apt-get install -y cmake libmagic-dev
  206. - echo "import Mix.Config" > config/prod.secret.exs
  207. - mix local.hex --force
  208. - mix local.rebar --force
  209. script: &release
  210. - mix deps.get --only prod
  211. - mkdir release
  212. - export PLEROMA_BUILD_BRANCH=$CI_COMMIT_REF_NAME
  213. - mix release --path release
  214. amd64-musl:
  215. stage: release
  216. artifacts: *release-artifacts
  217. only: *release-only
  218. image: elixir:1.10.3-alpine
  219. cache: *release-cache
  220. variables: *release-variables
  221. before_script: &before-release-musl
  222. - apk add git gcc g++ musl-dev make cmake file-dev
  223. - echo "import Mix.Config" > config/prod.secret.exs
  224. - mix local.hex --force
  225. - mix local.rebar --force
  226. script: *release
  227. arm:
  228. stage: release
  229. artifacts: *release-artifacts
  230. only: *release-only
  231. tags:
  232. - arm32-specified
  233. image: arm32v7/elixir:1.10.3
  234. cache: *release-cache
  235. variables: *release-variables
  236. before_script: *before-release
  237. script: *release
  238. arm-musl:
  239. stage: release
  240. artifacts: *release-artifacts
  241. only: *release-only
  242. tags:
  243. - arm32-specified
  244. image: arm32v7/elixir:1.10.3-alpine
  245. cache: *release-cache
  246. variables: *release-variables
  247. before_script: *before-release-musl
  248. script: *release
  249. arm64:
  250. stage: release
  251. artifacts: *release-artifacts
  252. only: *release-only
  253. tags:
  254. - arm
  255. image: arm64v8/elixir:1.10.3
  256. cache: *release-cache
  257. variables: *release-variables
  258. before_script: *before-release
  259. script: *release
  260. arm64-musl:
  261. stage: release
  262. artifacts: *release-artifacts
  263. only: *release-only
  264. tags:
  265. - arm
  266. image: arm64v8/elixir:1.10.3-alpine
  267. cache: *release-cache
  268. variables: *release-variables
  269. before_script: *before-release-musl
  270. script: *release
  271. docker:
  272. stage: docker
  273. image: docker:latest
  274. cache: {}
  275. dependencies: []
  276. variables: &docker-variables
  277. DOCKER_DRIVER: overlay2
  278. DOCKER_HOST: unix:///var/run/docker.sock
  279. IMAGE_TAG: $CI_REGISTRY_IMAGE:$CI_COMMIT_SHORT_SHA
  280. IMAGE_TAG_SLUG: $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
  281. IMAGE_TAG_LATEST: $CI_REGISTRY_IMAGE:latest
  282. IMAGE_TAG_LATEST_STABLE: $CI_REGISTRY_IMAGE:latest-stable
  283. DOCKER_BUILDX_URL: https://github.com/docker/buildx/releases/download/v0.4.1/buildx-v0.4.1.linux-amd64
  284. DOCKER_BUILDX_HASH: 71a7d01439aa8c165a25b59c44d3f016fddbd98b
  285. before_script: &before-docker
  286. - docker login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY
  287. - docker pull $IMAGE_TAG_SLUG || true
  288. - export CI_JOB_TIMESTAMP=$(date --utc -Iseconds)
  289. - export CI_VCS_REF=$CI_COMMIT_SHORT_SHA
  290. allow_failure: true
  291. script:
  292. - mkdir -p /root/.docker/cli-plugins
  293. - wget "${DOCKER_BUILDX_URL}" -O ~/.docker/cli-plugins/docker-buildx
  294. - echo "${DOCKER_BUILDX_HASH} /root/.docker/cli-plugins/docker-buildx" | sha1sum -c
  295. - chmod +x ~/.docker/cli-plugins/docker-buildx
  296. - docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
  297. - docker buildx create --name mbuilder --driver docker-container --use
  298. - docker buildx inspect --bootstrap
  299. - 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 .
  300. tags:
  301. - dind
  302. only:
  303. - develop@pleroma/pleroma
  304. docker-stable:
  305. stage: docker
  306. image: docker:latest
  307. cache: {}
  308. dependencies: []
  309. variables: *docker-variables
  310. before_script: *before-docker
  311. allow_failure: true
  312. script:
  313. - mkdir -p /root/.docker/cli-plugins
  314. - wget "${DOCKER_BUILDX_URL}" -O ~/.docker/cli-plugins/docker-buildx
  315. - echo "${DOCKER_BUILDX_HASH} /root/.docker/cli-plugins/docker-buildx" | sha1sum -c
  316. - chmod +x ~/.docker/cli-plugins/docker-buildx
  317. - docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
  318. - docker buildx create --name mbuilder --driver docker-container --use
  319. - docker buildx inspect --bootstrap
  320. - 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 .
  321. tags:
  322. - dind
  323. only:
  324. - stable@pleroma/pleroma
  325. docker-release:
  326. stage: docker
  327. image: docker:latest
  328. cache: {}
  329. dependencies: []
  330. variables: *docker-variables
  331. before_script: *before-docker
  332. allow_failure: true
  333. script:
  334. script:
  335. - mkdir -p /root/.docker/cli-plugins
  336. - wget "${DOCKER_BUILDX_URL}" -O ~/.docker/cli-plugins/docker-buildx
  337. - echo "${DOCKER_BUILDX_HASH} /root/.docker/cli-plugins/docker-buildx" | sha1sum -c
  338. - chmod +x ~/.docker/cli-plugins/docker-buildx
  339. - docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
  340. - docker buildx create --name mbuilder --driver docker-container --use
  341. - docker buildx inspect --bootstrap
  342. - 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 .
  343. tags:
  344. - dind
  345. only:
  346. - /^release/.*$/@pleroma/pleroma
  347. docker-adhoc:
  348. stage: docker
  349. image: docker:latest
  350. cache: {}
  351. dependencies: []
  352. variables: *docker-variables
  353. before_script: *before-docker
  354. allow_failure: true
  355. script:
  356. script:
  357. - mkdir -p /root/.docker/cli-plugins
  358. - wget "${DOCKER_BUILDX_URL}" -O ~/.docker/cli-plugins/docker-buildx
  359. - echo "${DOCKER_BUILDX_HASH} /root/.docker/cli-plugins/docker-buildx" | sha1sum -c
  360. - chmod +x ~/.docker/cli-plugins/docker-buildx
  361. - docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
  362. - docker buildx create --name mbuilder --driver docker-container --use
  363. - docker buildx inspect --bootstrap
  364. - 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 .
  365. tags:
  366. - dind
  367. only:
  368. - /^build-docker/.*$/@pleroma/pleroma