smarthbs/.gitlab-ci.yml

151 lines
2.9 KiB
YAML
Raw Normal View History

2019-09-10 15:58:14 +00:00
# gitzone ci_default
2017-03-14 18:33:04 +00:00
image: hosttoday/ht-docker-node:npmci
2017-02-26 01:09:41 +00:00
2017-03-14 19:15:31 +00:00
cache:
paths:
- .npmci_cache/
2017-03-14 19:15:31 +00:00
key: "$CI_BUILD_STAGE"
2017-02-26 01:09:41 +00:00
stages:
- security
2017-02-26 01:09:41 +00:00
- test
- release
- metadata
2017-02-26 01:09:41 +00:00
# ====================
# security stage
# ====================
mirror:
stage: security
script:
- npmci git mirror
tags:
- docker
- notpriv
snyk:
stage: security
script:
2019-02-17 16:02:35 +00:00
- npmci npm prepare
- npmci command npm install -g snyk
- npmci command npm install --ignore-scripts
- npmci command snyk test
tags:
- docker
- notpriv
2019-02-17 16:02:35 +00:00
sast:
stage: security
image: registry.gitlab.com/hosttoday/ht-docker-dbase:npmci
variables:
DOCKER_DRIVER: overlay2
allow_failure: true
services:
- docker:stable-dind
2017-02-26 01:09:41 +00:00
script:
2019-02-17 16:02:35 +00:00
- npmci npm prepare
- npmci npm install
- npmci command npm run build
- export SP_VERSION=$(echo "$CI_SERVER_VERSION" | sed 's/^\([0-9]*\)\.\([0-9]*\).*/\1-\2-stable/')
- docker run
--env SAST_CONFIDENCE_LEVEL="${SAST_CONFIDENCE_LEVEL:-3}"
--volume "$PWD:/code"
--volume /var/run/docker.sock:/var/run/docker.sock
"registry.gitlab.com/gitlab-org/security-products/sast:$SP_VERSION" /app/bin/run /code
artifacts:
reports:
sast: gl-sast-report.json
2017-02-26 01:09:41 +00:00
tags:
- docker
2019-02-17 16:02:35 +00:00
- priv
# ====================
# test stage
# ====================
2017-02-26 01:09:41 +00:00
testLTS:
stage: test
script:
2019-02-17 16:02:35 +00:00
- npmci npm prepare
- npmci node install lts
- npmci npm install
- npmci npm test
2017-02-26 01:09:41 +00:00
coverage: /\d+.?\d+?\%\s*coverage/
tags:
- docker
- notpriv
2017-02-26 01:09:41 +00:00
testSTABLE:
stage: test
script:
2019-02-17 16:02:35 +00:00
- npmci npm prepare
- npmci node install stable
- npmci npm install
- npmci npm test
2017-02-26 01:09:41 +00:00
coverage: /\d+.?\d+?\%\s*coverage/
tags:
- docker
- notpriv
2017-02-26 01:09:41 +00:00
release:
stage: release
script:
- npmci node install stable
- npmci npm publish
2017-02-26 01:09:41 +00:00
only:
- tags
2017-02-26 01:09:41 +00:00
tags:
- docker
- notpriv
# ====================
# metadata stage
# ====================
codequality:
stage: metadata
image: docker:stable
allow_failure: true
services:
- docker:stable-dind
script:
- export SP_VERSION=$(echo "$CI_SERVER_VERSION" | sed 's/^\([0-9]*\)\.\([0-9]*\).*/\1-\2-stable/')
- docker run
--env SOURCE_CODE="$PWD"
--volume "$PWD":/code
--volume /var/run/docker.sock:/var/run/docker.sock
"registry.gitlab.com/gitlab-org/security-products/codequality:$SP_VERSION" /code
artifacts:
paths: [codeclimate.json]
tags:
- docker
- priv
2017-02-26 01:09:41 +00:00
trigger:
stage: metadata
2017-02-26 01:09:41 +00:00
script:
- npmci trigger
2017-02-26 01:09:41 +00:00
only:
- tags
2017-02-26 01:09:41 +00:00
tags:
- docker
- notpriv
2017-02-26 01:09:41 +00:00
pages:
2017-03-14 19:15:31 +00:00
image: hosttoday/ht-docker-node:npmci
stage: metadata
2017-02-26 01:09:41 +00:00
script:
- npmci command npm install -g typedoc typescript
2019-02-17 16:02:35 +00:00
- npmci npm prepare
- npmci npm install
- npmci command typedoc --module "commonjs" --target "ES2016" --out public/ ts/
2017-03-14 19:15:31 +00:00
tags:
- docker
- notpriv
2017-02-26 01:09:41 +00:00
only:
- tags
artifacts:
expire_in: 1 week
paths:
- public
allow_failure: true