forked from dseira/rundeck-formula
-
Notifications
You must be signed in to change notification settings - Fork 7
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #10 from noelmcloughlin/refactor
Refactor(rewrite): align to template-formula
- Loading branch information
Showing
80 changed files
with
3,805 additions
and
712 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
# -*- coding: utf-8 -*- | ||
# vim: ft=yaml | ||
--- | ||
name: Commitlint | ||
'on': [pull_request] | ||
|
||
jobs: | ||
lint: | ||
runs-on: ubuntu-latest | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
steps: | ||
- uses: actions/checkout@v2 | ||
with: | ||
fetch-depth: 0 | ||
- uses: wagoid/commitlint-github-action@v1 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,122 @@ | ||
# Byte-compiled / optimized / DLL files | ||
__pycache__/ | ||
*.py[cod] | ||
*$py.class | ||
|
||
# C extensions | ||
*.so | ||
|
||
# Distribution / packaging | ||
.Python | ||
env/ | ||
build/ | ||
develop-eggs/ | ||
dist/ | ||
downloads/ | ||
eggs/ | ||
.eggs/ | ||
lib/ | ||
lib64/ | ||
parts/ | ||
sdist/ | ||
var/ | ||
wheels/ | ||
*.egg-info/ | ||
.installed.cfg | ||
*.egg | ||
|
||
# PyInstaller | ||
# Usually these files are written by a python script from a packager | ||
# before PyInstaller builds the exe, so as to inject date/other infos into it. | ||
*.manifest | ||
*.spec | ||
|
||
# Installer logs | ||
pip-log.txt | ||
pip-delete-this-directory.txt | ||
|
||
# Unit test / coverage reports | ||
htmlcov/ | ||
.tox/ | ||
.coverage | ||
.coverage.* | ||
.cache | ||
nosetests.xml | ||
coverage.xml | ||
*.cover | ||
.hypothesis/ | ||
.kitchen | ||
.kitchen.local.yml | ||
kitchen.local.yml | ||
junit-*.xml | ||
|
||
# Translations | ||
*.mo | ||
*.pot | ||
|
||
# Django stuff: | ||
*.log | ||
local_settings.py | ||
|
||
# Flask stuff: | ||
instance/ | ||
.webassets-cache | ||
|
||
# Scrapy stuff: | ||
.scrapy | ||
|
||
# Sphinx documentation | ||
docs/_build/ | ||
|
||
# PyBuilder | ||
target/ | ||
|
||
# Jupyter Notebook | ||
.ipynb_checkpoints | ||
|
||
# pyenv | ||
.python-version | ||
|
||
# celery beat schedule file | ||
celerybeat-schedule | ||
|
||
# SageMath parsed files | ||
*.sage.py | ||
|
||
# dotenv | ||
.env | ||
|
||
# virtualenv | ||
.venv | ||
venv/ | ||
ENV/ | ||
|
||
# Spyder project settings | ||
.spyderproject | ||
.spyproject | ||
|
||
# Rope project settings | ||
.ropeproject | ||
|
||
# mkdocs documentation | ||
/site | ||
|
||
# mypy | ||
.mypy_cache/ | ||
|
||
# Bundler | ||
.bundle/ | ||
|
||
# copied `.md` files used for conversion to `.rst` using `m2r` | ||
docs/*.md | ||
|
||
# Vim | ||
*.sw? | ||
|
||
## Collected when centralising formulas (check and sort) | ||
# `collectd-formula` | ||
.pytest_cache/ | ||
/.idea/ | ||
Dockerfile.*_* | ||
ignore/ | ||
tmp/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
# -*- coding: utf-8 -*- | ||
# vim: ft=yaml | ||
--- | ||
# See https://pre-commit.com for more information | ||
# See https://pre-commit.com/hooks.html for more hooks | ||
default_stages: [commit] | ||
repos: | ||
- repo: https://github.com/dafyddj/commitlint-pre-commit-hook | ||
rev: v2.3.0 | ||
hooks: | ||
- id: commitlint | ||
name: Check commit message using commitlint | ||
description: Lint commit message against @commitlint/config-conventional rules | ||
stages: [commit-msg] | ||
additional_dependencies: ['@commitlint/[email protected]'] | ||
- id: commitlint-travis | ||
stages: [manual] | ||
additional_dependencies: ['@commitlint/[email protected]'] | ||
always_run: true | ||
- repo: https://github.com/adithyabsk/mirrors-rubocop | ||
rev: v0.91.0 | ||
hooks: | ||
- id: rubocop | ||
name: Check Ruby files with rubocop | ||
args: [--debug] | ||
always_run: true | ||
pass_filenames: false | ||
- repo: https://github.com/jumanjihouse/pre-commit-hooks | ||
rev: 2.1.3 | ||
hooks: | ||
- id: shellcheck | ||
name: Check shell scripts with shellcheck | ||
files: ^.*\.(sh|bash|ksh)$ | ||
types: [] | ||
args: [] | ||
- repo: https://github.com/adrienverge/yamllint.git | ||
rev: v1.23.0 | ||
hooks: | ||
- id: yamllint | ||
name: Check YAML syntax with yamllint | ||
args: [--strict, '.'] | ||
always_run: true | ||
pass_filenames: false | ||
- repo: https://github.com/warpnet/salt-lint | ||
rev: v0.3.0 | ||
hooks: | ||
- id: salt-lint | ||
name: Check Salt files using salt-lint | ||
files: ^.*\.(sls|jinja|j2|tmpl|tst)$ | ||
- repo: https://github.com/myint/rstcheck | ||
rev: 3f929574 | ||
hooks: | ||
- id: rstcheck | ||
name: Check reST files using rstcheck | ||
exclude: 'docs/CHANGELOG.rst' | ||
args: [--report=warning] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
[rstcheck] | ||
report=error | ||
ignore_language=rst |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
# -*- coding: utf-8 -*- | ||
# vim: ft=yaml | ||
--- | ||
# General overrides used across formulas in the org | ||
Layout/LineLength: | ||
# Increase from default of `80` | ||
# Based on https://github.com/PyCQA/flake8-bugbear#opinionated-warnings (`B950`) | ||
Max: 88 | ||
Metrics/BlockLength: | ||
ExcludedMethods: | ||
- control | ||
- describe | ||
# Increase from default of `25` | ||
Max: 30 | ||
|
||
# Any offenses that should be fixed, e.g. collected via. `rubocop --auto-gen-config` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
# -*- coding: utf-8 -*- | ||
# vim: ft=yaml | ||
--- | ||
exclude_paths: [] | ||
rules: {} | ||
skip_list: | ||
# Using `salt-lint` for linting other files as well, such as Jinja macros/templates | ||
- 205 # Use ".sls" as a Salt State file extension | ||
# Skipping `207` and `208` because `210` is sufficient, at least for the time-being | ||
# I.e. Allows 3-digit unquoted codes to still be used, such as `644` and `755` | ||
- 207 # File modes should always be encapsulated in quotation marks | ||
- 208 # File modes should always contain a leading zero | ||
tags: [] | ||
verbosity: 1 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,159 @@ | ||
# -*- coding: utf-8 -*- | ||
# vim: ft=yaml | ||
--- | ||
## Machine config | ||
os: 'linux' | ||
arch: 'amd64' | ||
dist: 'bionic' | ||
version: '~> 1.0' | ||
|
||
## Language and cache config | ||
language: 'ruby' | ||
cache: 'bundler' | ||
|
||
## Services config | ||
services: | ||
- docker | ||
|
||
## Script to run for the test stage | ||
script: | ||
- bin/kitchen verify "${INSTANCE}" | ||
|
||
## Stages and jobs matrix | ||
stages: | ||
- test | ||
- name: 'release' | ||
if: 'branch = master AND type != pull_request' | ||
jobs: | ||
include: | ||
## Define the test stage that runs the linters (and testing matrix, if applicable) | ||
|
||
# Run all of the linters in a single job | ||
- language: 'node_js' | ||
node_js: 'lts/*' | ||
env: 'Lint' | ||
name: 'Lint: salt-lint, yamllint, rubocop, shellcheck & commitlint' | ||
before_install: 'skip' | ||
script: | ||
# Install and run `salt-lint` | ||
- pip install --user salt-lint | ||
- git ls-files -- '*.sls' '*.jinja' '*.j2' '*.tmpl' '*.tst' | ||
| xargs 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 `rubocop` | ||
- gem install rubocop | ||
- rubocop -d | ||
# Run `shellcheck` (already pre-installed in Travis) | ||
- shellcheck --version | ||
- git ls-files -- '*.sh' '*.bash' '*.ksh' | ||
| xargs shellcheck | ||
# Install and run `commitlint` | ||
- npm i -D @commitlint/config-conventional | ||
@commitlint/travis-cli | ||
- commitlint-travis | ||
|
||
# Run `pre-commit` linters in a single job | ||
- language: 'python' | ||
env: 'Lint_pre-commit' | ||
name: 'Lint: pre-commit' | ||
before_install: 'skip' | ||
cache: | ||
directories: | ||
- $HOME/.cache/pre-commit | ||
script: | ||
# Install and run `pre-commit` | ||
- pip install pre-commit==2.7.1 | ||
- pre-commit run --all-files --color always --verbose | ||
- pre-commit run --color always --hook-stage manual --verbose commitlint-travis | ||
|
||
## Define the rest of the matrix based on Kitchen testing | ||
# Make sure the instances listed below match up with | ||
# the `platforms` defined in `kitchen.yml` | ||
# NOTE: Please try to select up to six instances that add some meaningful | ||
# testing of the formula's behaviour. If possible, try to refrain from | ||
# the classical "chosing all the instances because I want to test on | ||
# another/all distro/s" trap: it will just add time to the testing (see | ||
# the discussion on #121). As an example, the set chosen below covers | ||
# the most used distros families, systemd and non-systemd and the latest | ||
# three supported Saltstack versions with python2 and 3. | ||
# As for `kitchen.yml`, that should still contain all of the platforms, | ||
# to allow for comprehensive local testing | ||
# Ref: https://github.com/saltstack-formulas/template-formula/issues/118 | ||
# Ref: https://github.com/saltstack-formulas/template-formula/issues/121 | ||
- env: INSTANCE=clean-debian-10-tiamat-py3 | ||
# - env: INSTANCE=default-debian-9-tiamat-py3 | ||
- env: INSTANCE=default-ubuntu-2004-tiamat-py3 | ||
# - env: INSTANCE=default-ubuntu-1804-tiamat-py3 | ||
# - env: INSTANCE=default-ubuntu-1604-tiamat-py3 | ||
- env: INSTANCE=default-centos-8-tiamat-py3 | ||
# - env: INSTANCE=default-centos-7-tiamat-py3 | ||
# env: INSTANCE=default-amazonlinux-2-tiamat-py3 | ||
# env: INSTANCE=default-oraclelinux-8-tiamat-py3 | ||
# - env: INSTANCE=default-oraclelinux-7-tiamat-py3 | ||
# - env: INSTANCE=default-debian-10-master-py3 | ||
# - env: INSTANCE=default-ubuntu-2004-master-py3 | ||
# - env: INSTANCE=default-ubuntu-1804-master-py3 | ||
# - env: INSTANCE=default-centos-8-master-py3 | ||
- env: INSTANCE=default-fedora-32-master-py3 | ||
# - env: INSTANCE=default-fedora-31-master-py3 | ||
- env: INSTANCE=default-opensuse-leap-152-master-py3 | ||
# - env: INSTANCE=default-amazonlinux-2-master-py3 | ||
# env: INSTANCE=default-gentoo-stage3-latest-master-py3 | ||
# env: INSTANCE=default-gentoo-stage3-systemd-master-py3 | ||
# - env: INSTANCE=default-debian-10-3001-py3 | ||
# - env: INSTANCE=default-debian-9-3001-py3 | ||
# - env: INSTANCE=default-ubuntu-2004-3001-py3 | ||
# - env: INSTANCE=default-ubuntu-1804-3001-py3 | ||
# - env: INSTANCE=default-centos-8-3001-py3 | ||
# - env: INSTANCE=default-centos-7-3001-py3 | ||
# - env: INSTANCE=default-fedora-32-3001-py3 | ||
# - env: INSTANCE=default-fedora-31-3001-py3 | ||
# - env: INSTANCE=default-opensuse-leap-152-3001-py3 | ||
# - env: INSTANCE=default-amazonlinux-2-3001-py3 | ||
# - env: INSTANCE=default-oraclelinux-8-3001-py3 | ||
# - env: INSTANCE=default-oraclelinux-7-3001-py3 | ||
# - env: INSTANCE=default-gentoo-stage3-latest-3001-py3 | ||
# - env: INSTANCE=default-gentoo-stage3-systemd-3001-py3 | ||
# - env: INSTANCE=default-debian-10-3000-3-py3 | ||
# - env: INSTANCE=default-debian-9-3000-3-py3 | ||
# - env: INSTANCE=default-ubuntu-1804-3000-3-py3 | ||
# - env: INSTANCE=default-centos-8-3000-3-py3 | ||
# - env: INSTANCE=default-centos-7-3000-3-py3 | ||
# - env: INSTANCE=default-fedora-31-3000-3-py3 | ||
# - env: INSTANCE=default-opensuse-leap-152-3000-3-py3 | ||
# - env: INSTANCE=default-amazonlinux-2-3000-3-py3 | ||
# - env: INSTANCE=default-gentoo-stage3-latest-3000-3-py3 | ||
# - env: INSTANCE=default-gentoo-stage3-systemd-3000-3-py3 | ||
# - env: INSTANCE=default-ubuntu-1804-3000-3-py2 | ||
# - env: INSTANCE=default-ubuntu-1604-3000-3-py2 | ||
- env: INSTANCE=default-arch-base-latest-3000-3-py2 | ||
- env: INSTANCE=clean-arch-base-latest-3000-3-py2 | ||
|
||
## 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 i -D @semantic-release/changelog@3 | ||
@semantic-release/exec@3 | ||
@semantic-release/git@7 | ||
deploy: | ||
provider: 'script' | ||
# Opt-in to `dpl v2` to complete the Travis build config validation (beta) | ||
# * https://docs.travis-ci.com/user/build-config-validation | ||
# Deprecated `skip_cleanup` can now be avoided, `cleanup: false` is by default | ||
edge: true | ||
# Run `semantic-release` | ||
script: 'npx [email protected]' |
Oops, something went wrong.