Saltstack Official FirewallD Formula
Du kannst nicht mehr als 25 Themen auswählen Themen müssen entweder mit einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

187 Zeilen
7.7KB

  1. # -*- coding: utf-8 -*-
  2. # vim: ft=yaml
  3. ---
  4. ################################################################################
  5. # NOTE: This file is UNMAINTAINED; it is provided for references purposes only.
  6. # No guarantees are tendered that this structure will work after 2020.
  7. ################################################################################
  8. # * https://en.wikipedia.org/wiki/Travis_CI:
  9. # - "... free open-source plans were removed in [sic] the end of 2020"
  10. # - https://blog.travis-ci.com/2020-11-02-travis-ci-new-billing
  11. # - https://ropensci.org/technotes/2020/11/19/moving-away-travis/
  12. ################################################################################
  13. ## Machine config
  14. os: 'linux'
  15. arch: 'amd64'
  16. dist: 'bionic'
  17. version: '~> 1.0'
  18. ## Language and cache config
  19. language: 'ruby'
  20. cache: 'bundler'
  21. ## Services config
  22. services:
  23. - docker
  24. ## Script to run for the test stage
  25. script:
  26. - bin/kitchen verify "${INSTANCE}"
  27. ## Stages and jobs matrix
  28. stages:
  29. - test
  30. # # As part of the switch away from Travis CI, ensure that the `release` stage
  31. # # is not run inadvertently
  32. # - name: 'release'
  33. # if: 'branch = master AND type != pull_request'
  34. jobs:
  35. include:
  36. ## Define the test stage that runs the linters (and testing matrix, if applicable)
  37. # Run all of the linters in a single job
  38. - language: 'node_js'
  39. node_js: 'lts/*'
  40. env: 'Lint'
  41. name: 'Lint: salt-lint, yamllint, rubocop, shellcheck & commitlint'
  42. before_install: 'skip'
  43. script:
  44. # Install and run `salt-lint`
  45. - pip install --user salt-lint
  46. - git ls-files -- '*.sls' '*.jinja' '*.j2' '*.tmpl' '*.tst'
  47. | xargs salt-lint
  48. # Install and run `yamllint`
  49. # Need at least `v1.17.0` for the `yaml-files` setting
  50. - pip install --user yamllint>=1.17.0
  51. - yamllint -s .
  52. # Install and run `rubocop`
  53. - gem install rubocop
  54. - rubocop -d
  55. # Run `shellcheck` (already pre-installed in Travis)
  56. - shellcheck --version
  57. - git ls-files -- '*.sh' '*.bash' '*.ksh'
  58. | xargs shellcheck
  59. # Install and run `commitlint`
  60. - npm i -D @commitlint/config-conventional
  61. @commitlint/travis-cli
  62. - commitlint-travis
  63. # Run `pre-commit` linters in a single job
  64. - language: 'python'
  65. env: 'Lint_pre-commit'
  66. name: 'Lint: pre-commit'
  67. before_install: 'skip'
  68. cache:
  69. directories:
  70. - $HOME/.cache/pre-commit
  71. script:
  72. # Install and run `pre-commit`
  73. - pip install pre-commit==2.7.1
  74. - pre-commit run --all-files --color always --verbose
  75. - pre-commit run --color always --hook-stage manual --verbose commitlint-travis
  76. ## Define the rest of the matrix based on Kitchen testing
  77. # Make sure the instances listed below match up with
  78. # the `platforms` defined in `kitchen.yml`
  79. # - env: INSTANCE=default-debian-11-tiamat-py3
  80. # - env: INSTANCE=default-debian-10-tiamat-py3
  81. # - env: INSTANCE=default-debian-9-tiamat-py3
  82. # - env: INSTANCE=default-ubuntu-2204-tiamat-py3
  83. # - env: INSTANCE=default-ubuntu-2004-tiamat-py3
  84. # - env: INSTANCE=default-ubuntu-1804-tiamat-py3
  85. # - env: INSTANCE=default-centos-stream8-tiamat-py3
  86. # - env: INSTANCE=default-centos-7-tiamat-py3
  87. # - env: INSTANCE=default-amazonlinux-2-tiamat-py3
  88. # - env: INSTANCE=default-oraclelinux-8-tiamat-py3
  89. # - env: INSTANCE=default-oraclelinux-7-tiamat-py3
  90. # - env: INSTANCE=default-almalinux-8-tiamat-py3
  91. # - env: INSTANCE=default-rockylinux-8-tiamat-py3
  92. # - env: INSTANCE=default-debian-11-master-py3
  93. # - env: INSTANCE=default-debian-10-master-py3
  94. - env: INSTANCE=default-debian-9-master-py3
  95. # - env: INSTANCE=default-ubuntu-2204-master-py3
  96. # - env: INSTANCE=default-ubuntu-2004-master-py3
  97. - env: INSTANCE=default-ubuntu-1804-master-py3
  98. - env: INSTANCE=default-centos-stream8-master-py3
  99. - env: INSTANCE=default-centos-7-master-py3
  100. - env: INSTANCE=default-fedora-36-master-py3
  101. - env: INSTANCE=default-fedora-35-master-py3
  102. - env: INSTANCE=default-opensuse-leap-153-master-py3
  103. - env: INSTANCE=default-opensuse-tmbl-latest-master-py3
  104. - env: INSTANCE=default-amazonlinux-2-master-py3
  105. - env: INSTANCE=default-oraclelinux-8-master-py3
  106. - env: INSTANCE=default-oraclelinux-7-master-py3
  107. - env: INSTANCE=default-arch-base-latest-master-py3
  108. # - env: INSTANCE=default-gentoo-stage3-latest-master-py3
  109. # - env: INSTANCE=default-gentoo-stage3-systemd-master-py3
  110. - env: INSTANCE=default-almalinux-8-master-py3
  111. - env: INSTANCE=default-rockylinux-8-master-py3
  112. # - env: INSTANCE=default-debian-11-3004-1-py3
  113. # - env: INSTANCE=default-debian-10-3004-1-py3
  114. # - env: INSTANCE=default-debian-9-3004-1-py3
  115. # - env: INSTANCE=default-ubuntu-2204-3004-1-py3
  116. # - env: INSTANCE=default-ubuntu-2004-3004-1-py3
  117. # - env: INSTANCE=default-ubuntu-1804-3004-1-py3
  118. # - env: INSTANCE=default-centos-stream8-3004-1-py3
  119. # - env: INSTANCE=default-centos-7-3004-1-py3
  120. # - env: INSTANCE=default-fedora-36-3004-1-py3
  121. # - env: INSTANCE=default-fedora-35-3004-1-py3
  122. # - env: INSTANCE=default-amazonlinux-2-3004-1-py3
  123. # - env: INSTANCE=default-oraclelinux-8-3004-1-py3
  124. # - env: INSTANCE=default-oraclelinux-7-3004-1-py3
  125. # - env: INSTANCE=default-arch-base-latest-3004-1-py3
  126. # - env: INSTANCE=default-gentoo-stage3-latest-3004-1-py3
  127. # - env: INSTANCE=default-gentoo-stage3-systemd-3004-1-py3
  128. # - env: INSTANCE=default-almalinux-8-3004-1-py3
  129. # - env: INSTANCE=default-rockylinux-8-3004-1-py3
  130. # - env: INSTANCE=default-opensuse-leap-153-3004-0-py3
  131. # - env: INSTANCE=default-opensuse-tmbl-latest-3004-0-py3
  132. # - env: INSTANCE=default-debian-10-3003-4-py3
  133. # - env: INSTANCE=default-debian-9-3003-4-py3
  134. # - env: INSTANCE=default-ubuntu-2004-3003-4-py3
  135. # - env: INSTANCE=default-ubuntu-1804-3003-4-py3
  136. # - env: INSTANCE=default-centos-stream8-3003-4-py3
  137. # - env: INSTANCE=default-centos-7-3003-4-py3
  138. # - env: INSTANCE=default-amazonlinux-2-3003-4-py3
  139. # - env: INSTANCE=default-oraclelinux-8-3003-4-py3
  140. # - env: INSTANCE=default-oraclelinux-7-3003-4-py3
  141. # - env: INSTANCE=default-almalinux-8-3003-4-py3
  142. ## Define the release stage that runs `semantic-release`
  143. - stage: 'release'
  144. language: 'node_js'
  145. node_js: 'lts/*'
  146. env: 'Release'
  147. name: 'Run semantic-release inc. file updates to AUTHORS, CHANGELOG & FORMULA'
  148. before_install: 'skip'
  149. script:
  150. # Update `AUTHORS.md`
  151. - export MAINTAINER_TOKEN=${GH_TOKEN}
  152. - go get github.com/myii/maintainer
  153. - maintainer contributor
  154. # Install all dependencies required for `semantic-release`
  155. - npm i -D @semantic-release/changelog@3
  156. @semantic-release/exec@3
  157. @semantic-release/git@7
  158. deploy:
  159. provider: 'script'
  160. # Opt-in to `dpl v2` to complete the Travis build config validation (beta)
  161. # * https://docs.travis-ci.com/user/build-config-validation
  162. # Deprecated `skip_cleanup` can now be avoided, `cleanup: false` is by default
  163. edge: true
  164. # Run `semantic-release`
  165. script: 'npx semantic-release@15.14'
  166. # Notification options: `always`, `never` or `change`
  167. notifications:
  168. webhooks:
  169. if: 'repo = saltstack-formulas/firewalld-formula'
  170. urls:
  171. - https://saltstack-formulas.zulipchat.com/api/v1/external/travis?api_key=HsIq3o5QmLxdnVCKF9is0FUIpkpAY79P&stream=CI&topic=saltstack-formulas%2Ffirewalld-formula&ignore_pull_requests=true
  172. on_success: always # default: always
  173. on_failure: always # default: always
  174. on_start: always # default: never
  175. on_cancel: always # default: always
  176. on_error: always # default: always