Saltstack Official Salt Formula
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

111 line
4.1KB

  1. # -*- coding: utf-8 -*-
  2. # vim: ft=yaml
  3. ---
  4. ## Machine config
  5. os: 'linux'
  6. arch: 'amd64'
  7. dist: 'bionic'
  8. version: '~> 1.0'
  9. ## Language and cache config
  10. language: 'ruby'
  11. cache: 'bundler'
  12. ## Services config
  13. services:
  14. - docker
  15. ## Script to run for the test stage
  16. script:
  17. - bin/kitchen verify "${INSTANCE}"
  18. ## Stages and jobs matrix
  19. stages:
  20. - test
  21. - name: 'release'
  22. if: 'branch = master AND type != pull_request'
  23. jobs:
  24. include:
  25. ## Define the test stage that runs the linters (and testing matrix, if applicable)
  26. # Run all of the linters in a single job
  27. - language: 'node_js'
  28. node_js: 'lts/*'
  29. env: 'Lint'
  30. name: 'Lint: salt-lint, yamllint, rubocop, shellcheck & commitlint'
  31. before_install: 'skip'
  32. script:
  33. # Install and run `salt-lint`
  34. - pip install --user salt-lint
  35. - git ls-files -- '*.sls' '*.jinja' '*.j2' '*.tmpl' '*.tst'
  36. | xargs salt-lint
  37. # Install and run `yamllint`
  38. # Need at least `v1.17.0` for the `yaml-files` setting
  39. - pip install --user yamllint>=1.17.0
  40. - yamllint -s .
  41. # Install and run `rubocop`
  42. - gem install rubocop
  43. - rubocop -d
  44. # Run `shellcheck` (already pre-installed in Travis)
  45. - shellcheck --version
  46. - git ls-files -- '*.sh' '*.bash' '*.ksh'
  47. | xargs shellcheck
  48. # Install and run `commitlint`
  49. - npm i -D @commitlint/config-conventional
  50. @commitlint/travis-cli
  51. - commitlint-travis
  52. ## Define the rest of the matrix based on Kitchen testing
  53. # Make sure the instances listed below match up with
  54. # the `platforms` defined in `kitchen.yml`
  55. # The ordering used below has been selected based on the time required in Travis
  56. # The slower ones are kept as high up as possible, to run concurrently rather than
  57. # slow down the entire run at the end (i.e. `centos-6` and `opensuse`)
  58. # However, the groupings needed to be maintained in some semblance of order
  59. # so this is a best-effort matrix, in the circumstances
  60. # - env: INSTANCE=v201707-py2-debian-8-2017-7-py2
  61. - env: INSTANCE=v201707-py2-ubuntu-1604-2017-7-py2
  62. - env: INSTANCE=v201707-py2-centos-6-2017-7-py2
  63. # - env: INSTANCE=v201707-py2-amazonlinux-1-2017-7-py2
  64. # - env: INSTANCE=v201707-py2-arch-base-latest-2017-7-py2
  65. - env: INSTANCE=v201803-py2-debian-9-2018-3-py2
  66. # - env: INSTANCE=v201803-py2-ubuntu-1604-2018-3-py2
  67. - env: INSTANCE=v201803-py2-centos-7-2018-3-py2
  68. # - env: INSTANCE=v201803-py2-amazonlinux-1-2018-3-py2
  69. # - env: INSTANCE=v201803-py2-arch-base-latest-2018-3-py2
  70. - env: INSTANCE=v201902-py2-ubuntu-1804-2019-2-py2
  71. # - env: INSTANCE=v201902-py2-centos-7-2019-2-py2
  72. - env: INSTANCE=v201902-py2-amazonlinux-2-2019-2-py3
  73. # - env: INSTANCE=v201902-py2-arch-base-latest-2019-2-py2
  74. - env: INSTANCE=v201902-py3-debian-10-2019-2-py3
  75. # - env: INSTANCE=v201902-py3-debian-9-2019-2-py3
  76. # - env: INSTANCE=v201902-py3-ubuntu-1804-2019-2-py3
  77. # - env: INSTANCE=v201902-py3-centos-8-2019-2-py3
  78. - env: INSTANCE=v201902-py3-opensuse-leap-151-2019-2-py3
  79. ## Define the release stage that runs `semantic-release`
  80. - stage: 'release'
  81. language: 'node_js'
  82. node_js: 'lts/*'
  83. env: 'Release'
  84. name: 'Run semantic-release inc. file updates to AUTHORS, CHANGELOG & FORMULA'
  85. before_install: 'skip'
  86. script:
  87. # Update `AUTHORS.md`
  88. - export MAINTAINER_TOKEN=${GH_TOKEN}
  89. - go get github.com/myii/maintainer
  90. - maintainer contributor
  91. # Install all dependencies required for `semantic-release`
  92. - npm i -D @semantic-release/changelog@3
  93. @semantic-release/exec@3
  94. @semantic-release/git@7
  95. deploy:
  96. provider: 'script'
  97. # Opt-in to `dpl v2` to complete the Travis build config validation (beta)
  98. # * https://docs.travis-ci.com/user/build-config-validation
  99. # Deprecated `skip_cleanup` can now be avoided, `cleanup: false` is by default
  100. edge: true
  101. # Run `semantic-release`
  102. script: 'npx semantic-release@15.14'