smartlog/.gitlab-ci.yml

151 lines
2.9 KiB
YAML
Raw Normal View History

2018-01-28 03:31:06 +00:00
# gitzone standard
2016-10-15 17:00:52 +00:00
image: hosttoday/ht-docker-node:npmci
2018-01-28 03:31:06 +00:00
cache:
paths:
2018-06-05 18:48:14 +00:00
- .npmci_cache/
2018-01-28 03:31:06 +00:00
key: "$CI_BUILD_STAGE"
2016-10-15 17:00:52 +00:00
stages:
2018-01-28 03:31:06 +00:00
- security
2016-10-15 17:00:52 +00:00
- test
- release
2018-06-05 18:48:14 +00:00
- metadata
2018-01-28 03:31:06 +00:00
2018-06-05 18:48:14 +00:00
# ====================
# security stage
# ====================
2018-01-28 03:31:06 +00:00
mirror:
2018-06-05 18:48:14 +00:00
stage: security
2018-01-28 03:31:06 +00:00
script:
- npmci git mirror
tags:
- docker
2018-06-05 18:48:14 +00:00
- notpriv
2018-01-28 03:31:06 +00:00
2018-06-05 18:48:14 +00:00
snyk:
2018-01-28 03:31:06 +00:00
stage: security
script:
2018-10-30 17:56:26 +00:00
- npmci npm prepare
2018-06-05 18:48:14 +00:00
- npmci command npm install -g snyk
- npmci command npm install --ignore-scripts
2018-01-28 03:31:06 +00:00
- npmci command snyk test
tags:
- docker
2018-06-05 18:48:14 +00:00
- notpriv
2018-01-28 03:31:06 +00:00
2019-01-15 23:01:19 +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
2016-10-15 17:00:52 +00:00
script:
2019-01-15 23:01:19 +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
2016-10-15 17:00:52 +00:00
tags:
2018-01-28 03:31:06 +00:00
- docker
2019-01-15 23:01:19 +00:00
- priv
# ====================
# test stage
# ====================
2018-01-28 03:31:06 +00:00
2016-10-15 17:00:52 +00:00
testLTS:
stage: test
script:
2018-10-30 17:56:26 +00:00
- npmci npm prepare
2018-01-28 03:31:06 +00:00
- npmci node install lts
- npmci npm install
- npmci npm test
coverage: /\d+.?\d+?\%\s*coverage/
2016-10-15 17:00:52 +00:00
tags:
2018-01-28 03:31:06 +00:00
- docker
2018-06-05 18:48:14 +00:00
- notpriv
2016-10-15 17:00:52 +00:00
testSTABLE:
stage: test
script:
2018-10-30 17:56:26 +00:00
- npmci npm prepare
2018-01-28 03:31:06 +00:00
- npmci node install stable
- npmci npm install
- npmci npm test
coverage: /\d+.?\d+?\%\s*coverage/
2016-10-15 17:00:52 +00:00
tags:
2018-01-28 03:31:06 +00:00
- docker
2018-06-05 18:48:14 +00:00
- notpriv
2018-01-28 03:31:06 +00:00
2016-10-15 17:00:52 +00:00
release:
stage: release
script:
2018-06-05 18:48:14 +00:00
- npmci node install stable
2018-01-28 03:31:06 +00:00
- npmci npm publish
2016-10-15 17:00:52 +00:00
only:
2018-01-28 03:31:06 +00:00
- tags
2016-10-15 17:00:52 +00:00
tags:
2018-01-28 03:31:06 +00:00
- docker
2018-06-05 18:48:14 +00:00
- 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
2018-01-28 03:31:06 +00:00
2016-10-15 17:00:52 +00:00
trigger:
2018-06-05 18:48:14 +00:00
stage: metadata
2016-10-15 17:00:52 +00:00
script:
2018-01-28 03:31:06 +00:00
- npmci trigger
2016-10-15 17:00:52 +00:00
only:
2018-01-28 03:31:06 +00:00
- tags
2016-10-15 17:00:52 +00:00
tags:
2018-01-28 03:31:06 +00:00
- docker
2018-06-05 18:48:14 +00:00
- notpriv
2018-01-28 03:31:06 +00:00
2016-10-15 17:00:52 +00:00
pages:
2018-01-28 03:31:06 +00:00
image: hosttoday/ht-docker-node:npmci
2018-06-05 18:48:14 +00:00
stage: metadata
2016-10-15 17:00:52 +00:00
script:
2018-10-30 17:56:26 +00:00
- npmci command npm install -g typedoc typescript
- npmci npm prepare
- npmci npm install
- npmci command typedoc --module "commonjs" --target "ES2016" --out public/ ts/
2018-01-28 03:31:06 +00:00
tags:
- docker
2018-06-05 18:48:14 +00:00
- notpriv
2016-10-15 17:00:52 +00:00
only:
- tags
artifacts:
expire_in: 1 week
paths:
2018-01-28 03:31:06 +00:00
- public
2018-07-08 20:30:21 +00:00
allow_failure: true