smartsocket/.gitlab-ci.yml

151 lines
2.9 KiB
YAML
Raw Permalink Normal View History

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