-
Reiter, Christoph authored
The behaviour should be the same, except the deployer command is now independent of the CWD. We also no longer ship deployer in the docker image, but install it via composer, so it's easier to update.
Reiter, Christoph authoredThe behaviour should be the same, except the deployer command is now independent of the CWD. We also no longer ship deployer in the docker image, but install it via composer, so it's easier to update.
.gitlab-ci.yml 2.10 KiB
image: registry.gitlab.tugraz.at/dbp/web-components/toolkit/main:v2
cache:
key: ${CI_PROJECT_PATH}
paths:
- _yarn_cache
before_script:
- yarn config set cache-folder "$CI_PROJECT_DIR/_yarn_cache"
stages:
- test
- deploy
- e2e
test:
stage: test
script:
- yarn install --frozen-lockfile
- yarn run test
linting:
stage: test
script:
- yarn install --frozen-lockfile
- yarn run lint
publish:
stage: deploy
only:
refs:
- deploy
- master
script:
# https://www.npmjs.com/settings/dbp-deploy/tokens
# NPM_TOKEN needs to be a "Publish" token with 2FA disabled!
# "Automation" tokens don't work with lerna (even if they would work with "npm publish")
- echo '//registry.npmjs.org/:_authToken=${NPM_TOKEN}' > ~/.npmrc
- yarn install --frozen-lockfile
- yarn run build
- yarn run publish
.deploy_defaults: &deploy_defaults
except:
- schedules
stage: deploy
script:
# Add ssh key
- mkdir -p ~/.ssh
- echo "${DEPLOY_KEY}" | tr -d '\r' > ~/.ssh/id_rsa
- chmod 700 ~/.ssh && chmod 600 ~/.ssh/id_rsa
- ssh-keyscan -t rsa "${DEPLOY_HOST}" >> ~/.ssh/known_hosts
# Deploy
- cd .gitlab-ci
- export DO_NOT_TRACK=1
- composer install
- composer exec -- deployer.phar deploy "stage=${CI_ENVIRONMENT_NAME}"
- echo "Deployed to ${CI_ENVIRONMENT_URL}"
# Simple health check
- curl --max-time 10 --retry 3 --output /dev/null --silent --show-error --fail --location "${CI_ENVIRONMENT_URL}"
deploy_demo:
only:
refs:
- demo
environment:
name: demo
url: https://dbp-demo.tugraz.at/apps/demo
variables:
DEPLOY_HOST: vpu01-demo.tugraz.at