# -*- coding: utf-8 -*- # vim: ft=yaml --- ## Machine config dist: bionic ## Stages and jobs matrix stages: - test - name: release if: branch = master AND type != pull_request jobs: allow_failures: - env: Lint_rubocop fast_finish: true include: ## Define the test stage that runs the linters (and testing matrix, if applicable) # Run all of the linters in a single job (except `rubocop`) - language: node_js node_js: lts/* env: Lint name: 'Lint: salt-lint, yamllint & commitlint' before_install: skip script: # Install and run `salt-lint` - pip install --user salt-lint - git ls-files | grep '\.sls$\|\.jinja$\|\.j2$\|\.tmpl$' | xargs -I {} salt-lint {} # Install and run `yamllint` # Need at least `v1.17.0` for the `yaml-files` setting - pip install --user yamllint>=1.17.0 - yamllint -s . # Install and run `commitlint` - npm install @commitlint/config-conventional -D - npm install @commitlint/travis-cli -D - commitlint-travis # Run the `rubocop` linter in a separate job that is allowed to fail # Once these lint errors are fixed, this can be merged into a single job - language: node_js node_js: lts/* env: Lint_rubocop name: 'Lint: rubocop' before_install: skip script: # Install and run `rubocop` - gem install rubocop - rubocop -d ## Define the release stage that runs `semantic-release` - stage: release language: node_js node_js: lts/* env: Release name: 'Run semantic-release inc. file updates to AUTHORS, CHANGELOG & FORMULA' before_install: skip script: # Update `AUTHORS.md` - export MAINTAINER_TOKEN=${GH_TOKEN} - go get github.com/myii/maintainer - maintainer contributor # Install all dependencies required for `semantic-release` - npm install @semantic-release/changelog@3 -D - npm install @semantic-release/exec@3 -D - npm install @semantic-release/git@7 -D deploy: provider: script skip_cleanup: true script: # Run `semantic-release` - npx semantic-release@15