territory/.gitlab-ci.yml

59 lines
1.6 KiB
YAML
Raw Normal View History

2023-02-06 12:50:07 +00:00
image: docker:20.10.22
stages:
- test
- build
include:
- template: Security/SAST.gitlab-ci.yml
- template: Security/Secret-Detection.gitlab-ci.yml
2023-02-06 12:50:07 +00:00
##############
# TEST STAGE #
##############
test:
stage: test
image: docker/compose:latest
variables:
2023-03-30 08:54:13 +00:00
DOCKER_TLS_CERTDIR: ''
2023-02-06 12:50:07 +00:00
services:
- docker:dind
script:
2023-02-09 08:10:44 +00:00
- docker-compose -f docker-compose.ci.tools.yml -p territory-tools --env-file ci/.env.ci up -d
2023-02-06 12:50:07 +00:00
- sh ci/wait-up.sh
2023-02-09 08:10:44 +00:00
- docker-compose -f docker-compose.ci.service.yml -p territory-service --env-file ci/.env.ci up -d
2023-02-28 10:16:14 +00:00
- docker exec -t v3-territory-api sh -c "npm run test:integration:ci"
2023-02-06 12:50:07 +00:00
coverage: /All files[^|]*\|[^|]*\s+([\d\.]+)/
rules:
2023-03-30 08:54:13 +00:00
- if: '$CI_MERGE_REQUEST_TARGET_BRANCH_NAME == $CI_DEFAULT_BRANCH || $CI_COMMIT_MESSAGE =~ /--check/ || $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH'
2023-02-06 12:50:07 +00:00
when: always
###############
# BUILD STAGE #
###############
build:
stage: build
image: docker:20.10.22
variables:
2023-03-30 08:54:13 +00:00
DOCKER_TLS_CERTDIR: ''
2023-02-06 12:50:07 +00:00
services:
- docker:dind
before_script:
2023-04-05 10:19:10 +00:00
- echo -n $CI_REGISTRY_PASSWORD | docker login -u $CI_REGISTRY_USER --password-stdin $CI_REGISTRY
2023-02-06 12:50:07 +00:00
script:
2023-04-05 10:19:10 +00:00
- export VERSION=$(docker run --rm -v "$PWD":/usr/src/app:ro -w /usr/src/app node:slim node -p "require('./package.json').version")
- docker pull $CI_REGISTRY_IMAGE:latest || true
- >
docker build
--pull
--cache-from $CI_REGISTRY_IMAGE:latest
--tag $CI_REGISTRY_IMAGE:$VERSION
--tag $CI_REGISTRY_IMAGE:latest
.
- docker push $CI_REGISTRY_IMAGE:$VERSION
- docker push $CI_REGISTRY_IMAGE:latest
2023-02-06 12:50:07 +00:00
only:
- main