npmci/.gitlab-ci.yml

148 lines
2.8 KiB
YAML
Raw Normal View History

2017-05-25 11:26:06 +00:00
# gitzone standard
2017-09-08 21:30:31 +00:00
image: hosttoday/ht-docker-node:npmci
2016-05-30 00:28:47 +00:00
2017-05-25 11:26:06 +00:00
cache:
paths:
2018-07-15 22:04:24 +00:00
- .npmci_cache/
2017-05-25 11:26:06 +00:00
key: "$CI_BUILD_STAGE"
2016-05-30 00:28:47 +00:00
stages:
2018-04-04 20:25:13 +00:00
- security
2016-06-05 12:28:45 +00:00
- test
2016-05-30 00:28:47 +00:00
- release
- metadata
2016-05-30 00:28:47 +00:00
# ====================
# security stage
# ====================
2017-09-08 21:30:31 +00:00
mirror:
2018-04-04 20:25:13 +00:00
stage: security
2017-09-08 21:30:31 +00:00
script:
- npmci git mirror
tags:
- docker
2018-05-03 18:07:49 +00:00
- notpriv
2017-09-08 21:25:53 +00:00
2018-04-04 20:25:13 +00:00
snyk:
stage: security
script:
2018-09-22 12:36:25 +00:00
- npmci npm prepare
2018-07-15 22:04:24 +00:00
- npmci command npm install -g snyk
- npmci command npm install --ignore-scripts
2018-04-04 20:25:13 +00:00
- npmci command snyk test
tags:
- docker
2018-05-03 18:07:49 +00:00
- notpriv
2018-12-24 01:13:04 +00:00
sast:
stage: security
image: docker:stable
variables:
DOCKER_DRIVER: overlay2
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 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
tags:
- docker
- priv
# ====================
# test stage
# ====================
2017-05-25 11:26:06 +00:00
testLTS:
2016-06-05 06:06:32 +00:00
stage: test
script:
2018-09-22 12:36:25 +00:00
- npmci npm prepare
2017-09-08 21:30:31 +00:00
- npmci node install lts
- npmci npm install
- npmci npm test
2017-05-25 11:26:06 +00:00
coverage: /\d+.?\d+?\%\s*coverage/
2016-06-05 06:06:32 +00:00
tags:
2017-09-08 21:30:31 +00:00
- docker
2018-05-03 18:07:49 +00:00
- notpriv
2016-06-05 06:06:32 +00:00
2017-05-25 11:26:06 +00:00
testSTABLE:
2016-06-05 06:06:32 +00:00
stage: test
script:
2018-09-22 12:36:25 +00:00
- npmci npm prepare
2018-05-03 19:29:35 +00:00
- npmci node install stable
2017-09-08 21:30:31 +00:00
- npmci npm install
- npmci npm test
2017-05-25 11:26:06 +00:00
coverage: /\d+.?\d+?\%\s*coverage/
2016-06-05 06:06:32 +00:00
tags:
2017-09-08 21:30:31 +00:00
- docker
2018-05-03 18:07:49 +00:00
- notpriv
2016-06-05 06:06:32 +00:00
2016-05-30 00:28:47 +00:00
release:
stage: release
script:
2018-05-04 13:58:11 +00:00
- npmci node install stable
2017-09-08 21:30:31 +00:00
- npmci npm publish
2016-05-30 00:28:47 +00:00
only:
2017-09-08 21:30:31 +00:00
- tags
2016-05-30 00:28:47 +00:00
tags:
2017-09-08 21:30:31 +00:00
- docker
2018-05-03 18:07:49 +00:00
- notpriv
2016-06-02 17:35:01 +00:00
# ====================
# 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
2016-06-02 18:09:28 +00:00
trigger:
stage: metadata
2016-06-02 17:35:01 +00:00
script:
2017-09-08 21:30:31 +00:00
- npmci trigger
2016-06-02 17:35:01 +00:00
only:
2017-09-08 21:30:31 +00:00
- tags
2016-06-02 17:35:01 +00:00
tags:
2017-09-08 21:30:31 +00:00
- docker
2018-05-03 18:07:49 +00:00
- notpriv
pages:
2017-05-25 11:26:06 +00:00
image: hosttoday/ht-docker-node:npmci
stage: metadata
script:
2018-07-15 22:04:24 +00:00
- npmci command npm install -g typedoc typescript
2018-09-22 12:36:25 +00:00
- npmci npm prepare
2018-07-15 22:04:24 +00:00
- npmci npm install
- npmci command typedoc --module "commonjs" --target "ES2016" --out public/ ts/
2017-03-24 21:00:14 +00:00
tags:
- docker
2018-05-03 18:07:49 +00:00
- notpriv
2017-05-25 11:26:06 +00:00
only:
- tags
artifacts:
expire_in: 1 week
paths:
- public
2018-07-15 22:04:24 +00:00
allow_failure: true