reduce ci duplications
This commit is contained in:
parent
2b2def54b7
commit
2516c03058
1 changed files with 39 additions and 41 deletions
|
@ -1,41 +1,46 @@
|
||||||
image: node:lts-buster
|
|
||||||
|
|
||||||
stages:
|
stages:
|
||||||
- test
|
- test
|
||||||
- package
|
- package
|
||||||
|
- security
|
||||||
- upload
|
- upload
|
||||||
|
|
||||||
cache:
|
.cljs-job: &cljs
|
||||||
key: ${CI_COMMIT_REF_SLUG}
|
image: node:lts-buster
|
||||||
paths:
|
cache:
|
||||||
- node_modules/
|
key: ${CI_COMMIT_REF_SLUG}
|
||||||
|
paths:
|
||||||
default:
|
- node_modules/
|
||||||
before_script:
|
before_script:
|
||||||
- apt update && apt -qqy install openjdk-11-jre-headless
|
- apt update && apt -qqy install openjdk-11-jre-headless
|
||||||
- npm install
|
- npm install
|
||||||
- npm install -g --save-dev shadow-cljs
|
- npm install -g --save-dev shadow-cljs
|
||||||
|
|
||||||
|
.js-job: &js-upload
|
||||||
|
image: node:lts-buster
|
||||||
|
cache:
|
||||||
|
key: ${CI_COMMIT_REF_SLUG}
|
||||||
|
paths:
|
||||||
|
- node_modules/
|
||||||
|
before_script:
|
||||||
|
- echo _auth=$NPM_PUBLSH_KEY >> .npmrc
|
||||||
|
- echo email=$NPM_PUBLSH_MAIL >> .npmrc
|
||||||
|
- echo always-auth=true >> .npmrc
|
||||||
|
- mkdir -p target/npm-build/mastodon_bot
|
||||||
|
- cp target/mastodon-bot.js target/npm-build/mastodon_bot/
|
||||||
|
- cp target/mastodon-bot.js.sha256 target/npm-build/mastodon_bot/
|
||||||
|
- cp target/mastodon-bot.js.sha512 target/npm-build/mastodon_bot/
|
||||||
|
- cp package.json target/npm-build/mastodon_bot/
|
||||||
|
- cp README.md target/npm-build/mastodon_bot/
|
||||||
|
|
||||||
build:
|
build:
|
||||||
|
<<: *cljs
|
||||||
stage: test
|
stage: test
|
||||||
script:
|
script:
|
||||||
- shadow-cljs compile test
|
- shadow-cljs compile test
|
||||||
|
|
||||||
sast:
|
|
||||||
variables:
|
|
||||||
SAST_EXCLUDED_ANALYZERS:
|
|
||||||
bandit, brakeman, flawfinder, gosec, kubesec, phpcs-security-audit,
|
|
||||||
pmd-apex, security-code-scan, sobelow, spotbugs
|
|
||||||
stage: test
|
|
||||||
before_script:
|
|
||||||
- echo "scan security"
|
|
||||||
include:
|
|
||||||
- template: Security/SAST.gitlab-ci.yml
|
|
||||||
|
|
||||||
package:
|
package:
|
||||||
|
<<: *cljs
|
||||||
stage: package
|
stage: package
|
||||||
rules:
|
|
||||||
- if: '$CI_COMMIT_BRANCH == "master"'
|
|
||||||
artifacts:
|
artifacts:
|
||||||
paths:
|
paths:
|
||||||
- target/
|
- target/
|
||||||
|
@ -45,38 +50,31 @@ package:
|
||||||
- sha256sum target/mastodon-bot.js > target/mastodon-bot.js.sha256
|
- sha256sum target/mastodon-bot.js > target/mastodon-bot.js.sha256
|
||||||
- sha512sum target/mastodon-bot.js > target/mastodon-bot.js.sha512
|
- sha512sum target/mastodon-bot.js > target/mastodon-bot.js.sha512
|
||||||
|
|
||||||
|
sast:
|
||||||
|
variables:
|
||||||
|
SAST_EXCLUDED_ANALYZERS:
|
||||||
|
bandit, brakeman, flawfinder, gosec, kubesec, phpcs-security-audit,
|
||||||
|
pmd-apex, security-code-scan, sobelow, spotbugs
|
||||||
|
stage: security
|
||||||
|
before_script:
|
||||||
|
- mkdir -p builds && cp -r target/ builds/
|
||||||
|
include:
|
||||||
|
- template: Security/SAST.gitlab-ci.yml
|
||||||
|
|
||||||
upload-prerelease:
|
upload-prerelease:
|
||||||
|
<<: *js-upload
|
||||||
stage: upload
|
stage: upload
|
||||||
rules:
|
rules:
|
||||||
- if: '$CI_COMMIT_BRANCH == "master" && $CI_COMMIT_TAG == null'
|
- if: '$CI_COMMIT_BRANCH == "master" && $CI_COMMIT_TAG == null'
|
||||||
before_script:
|
|
||||||
- echo _auth=$NPM_PUBLSH_KEY >> .npmrc
|
|
||||||
- echo email=$NPM_PUBLSH_MAIL >> .npmrc
|
|
||||||
- echo always-auth=true >> .npmrc
|
|
||||||
script:
|
script:
|
||||||
- mkdir -p target/npm-build/mastodon_bot
|
|
||||||
- cp target/mastodon-bot.js target/npm-build/mastodon_bot/
|
|
||||||
- cp target/mastodon-bot.js.sha256 target/npm-build/mastodon_bot/
|
|
||||||
- cp target/mastodon-bot.js.sha512 target/npm-build/mastodon_bot/
|
|
||||||
- cp package.json target/npm-build/mastodon_bot/
|
|
||||||
- cp README.md target/npm-build/mastodon_bot/
|
|
||||||
- npm version --no-git-tag-version prerelease
|
- npm version --no-git-tag-version prerelease
|
||||||
- npm publish ./target/npm-build/mastodon_bot --access public
|
- npm publish ./target/npm-build/mastodon_bot --access public
|
||||||
|
|
||||||
upload-release:
|
upload-release:
|
||||||
|
<<: *js-upload
|
||||||
stage: upload
|
stage: upload
|
||||||
rules:
|
rules:
|
||||||
- if: '$CI_COMMIT_BRANCH == "master" && $CI_COMMIT_TAG != null'
|
- if: '$CI_COMMIT_BRANCH == "master" && $CI_COMMIT_TAG != null'
|
||||||
before_script:
|
|
||||||
- echo _auth=$NPM_PUBLSH_KEY >> .npmrc
|
|
||||||
- echo email=$NPM_PUBLSH_MAIL >> .npmrc
|
|
||||||
- echo always-auth=true >> .npmrc
|
|
||||||
script:
|
script:
|
||||||
- mkdir -p target/npm-build/mastodon_bot
|
|
||||||
- cp target/mastodon-bot.js target/npm-build/mastodon_bot/
|
|
||||||
- cp target/mastodon-bot.js.sha256 target/npm-build/mastodon_bot/
|
|
||||||
- cp target/mastodon-bot.js.sha512 target/npm-build/mastodon_bot/
|
|
||||||
- cp package.json target/npm-build/mastodon_bot/
|
|
||||||
- cp README.md target/npm-build/mastodon_bot/
|
|
||||||
- npm version --no-git-tag-version $CI_COMMIT_TAG
|
- npm version --no-git-tag-version $CI_COMMIT_TAG
|
||||||
- npm publish ./target/npm-build/mastodon_bot --access public
|
- npm publish ./target/npm-build/mastodon_bot --access public
|
||||||
|
|
Reference in a new issue