maubot/.gitlab-ci.yml

76 lines
3.0 KiB
YAML
Raw Permalink Normal View History

2019-07-28 14:07:56 -04:00
image: docker:stable
stages:
2020-02-25 17:42:06 -05:00
- build frontend
2019-07-28 14:07:56 -04:00
- build
2020-02-25 15:32:32 -05:00
- manifest
2019-07-28 14:07:56 -04:00
default:
before_script:
- docker login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY
2020-02-25 17:42:06 -05:00
build frontend:
2024-08-06 11:51:36 -04:00
image: node:20-alpine
2020-02-25 17:42:06 -05:00
stage: build frontend
before_script: []
variables:
NODE_ENV: "production"
cache:
paths:
- maubot/management/frontend/node_modules
script:
- cd maubot/management/frontend
- yarn --prod
- yarn build
- mv build ../../../frontend
artifacts:
paths:
- frontend
expire_in: 1 hour
2020-02-25 15:32:32 -05:00
build amd64:
2019-07-28 14:07:56 -04:00
stage: build
2020-02-25 15:32:32 -05:00
tags:
- amd64
2019-07-28 14:07:56 -04:00
script:
2020-02-25 17:54:10 -05:00
- echo maubot/management/frontend >> .dockerignore
2019-07-28 14:07:56 -04:00
- docker pull $CI_REGISTRY_IMAGE:latest || true
2020-02-25 17:42:06 -05:00
- docker build --pull --cache-from $CI_REGISTRY_IMAGE:latest --tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-amd64 . -f Dockerfile.ci
2020-02-25 15:32:32 -05:00
- docker push $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-amd64
- docker rmi $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-amd64
2019-07-28 14:07:56 -04:00
2020-02-25 15:32:32 -05:00
build arm64:
stage: build
tags:
- arm64
2019-07-28 14:07:56 -04:00
script:
2020-02-25 17:54:10 -05:00
- echo maubot/management/frontend >> .dockerignore
2020-02-25 15:32:32 -05:00
- docker pull $CI_REGISTRY_IMAGE:latest || true
2020-02-25 17:42:06 -05:00
- docker build --pull --cache-from $CI_REGISTRY_IMAGE:latest --tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-arm64 . -f Dockerfile.ci
2020-02-25 15:32:32 -05:00
- docker push $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-arm64
- docker rmi $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-arm64
2019-07-28 14:07:56 -04:00
2020-02-25 15:32:32 -05:00
manifest:
stage: manifest
before_script:
- "mkdir -p $HOME/.docker && echo '{\"experimental\": \"enabled\"}' > $HOME/.docker/config.json"
- docker login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY
2019-07-28 14:07:56 -04:00
script:
2020-02-25 15:32:32 -05:00
- docker pull $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-amd64
- docker pull $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-arm64
- if [ "$CI_COMMIT_BRANCH" = "master" ]; then docker manifest create $CI_REGISTRY_IMAGE:latest $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-amd64 $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-arm64 && docker manifest push $CI_REGISTRY_IMAGE:latest; fi
- if [ "$CI_COMMIT_BRANCH" != "master" ]; then docker manifest create $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_NAME $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-amd64 $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-arm64 && docker manifest push $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_NAME; fi
2020-02-25 15:32:32 -05:00
- docker rmi $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-amd64 $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-arm64
2019-10-22 18:14:54 -04:00
2020-02-25 15:32:32 -05:00
build standalone amd64:
2019-10-22 18:14:54 -04:00
stage: build
2020-02-25 15:32:32 -05:00
tags:
- amd64
2019-10-22 18:14:54 -04:00
script:
- docker pull $CI_REGISTRY_IMAGE:standalone || true
2019-10-22 18:53:47 -04:00
- docker build --pull --cache-from $CI_REGISTRY_IMAGE:standalone --tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-standalone . -f maubot/standalone/Dockerfile
- if [ "$CI_COMMIT_BRANCH" = "master" ]; then docker tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-standalone $CI_REGISTRY_IMAGE:standalone && docker push $CI_REGISTRY_IMAGE:standalone; fi
- if [ "$CI_COMMIT_BRANCH" != "master" ]; then docker tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-standalone $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_NAME-standalone && docker push $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_NAME-standalone; fi
- docker rmi $CI_REGISTRY_IMAGE:standalone $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_NAME-standalone $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA-standalone || true