Skip to content

Commit fd88630

Browse files
authored
Merge pull request #108 from myii/ci/standardise-structure
chore: use `semantic-release` cross-formula standard structure
2 parents 455b89a + d4ad07d commit fd88630

File tree

6 files changed

+210
-54
lines changed

6 files changed

+210
-54
lines changed

.gitignore

Lines changed: 119 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,122 @@
1-
*.swp
1+
# Byte-compiled / optimized / DLL files
2+
__pycache__/
3+
*.py[cod]
4+
*$py.class
5+
6+
# C extensions
7+
*.so
8+
9+
# Distribution / packaging
10+
.Python
11+
env/
12+
build/
13+
develop-eggs/
14+
dist/
15+
downloads/
16+
eggs/
17+
.eggs/
18+
lib/
19+
lib64/
20+
parts/
21+
sdist/
22+
var/
23+
wheels/
24+
*.egg-info/
25+
.installed.cfg
26+
*.egg
27+
28+
# PyInstaller
29+
# Usually these files are written by a python script from a packager
30+
# before PyInstaller builds the exe, so as to inject date/other infos into it.
31+
*.manifest
32+
*.spec
33+
34+
# Installer logs
35+
pip-log.txt
36+
pip-delete-this-directory.txt
37+
38+
# Unit test / coverage reports
39+
htmlcov/
40+
.tox/
41+
.coverage
42+
.coverage.*
43+
.cache
44+
nosetests.xml
45+
coverage.xml
46+
*.cover
47+
.hypothesis/
248
.kitchen
349
.kitchen.local.yml
4-
.cache
50+
kitchen.local.yml
551
junit-*.xml
6-
__pycache__
52+
53+
# Translations
54+
*.mo
55+
*.pot
56+
57+
# Django stuff:
58+
*.log
59+
local_settings.py
60+
61+
# Flask stuff:
62+
instance/
63+
.webassets-cache
64+
65+
# Scrapy stuff:
66+
.scrapy
67+
68+
# Sphinx documentation
69+
docs/_build/
70+
71+
# PyBuilder
72+
target/
73+
74+
# Jupyter Notebook
75+
.ipynb_checkpoints
76+
77+
# pyenv
78+
.python-version
79+
80+
# celery beat schedule file
81+
celerybeat-schedule
82+
83+
# SageMath parsed files
84+
*.sage.py
85+
86+
# dotenv
87+
.env
88+
89+
# virtualenv
90+
.venv
91+
venv/
92+
ENV/
93+
94+
# Spyder project settings
95+
.spyderproject
96+
.spyproject
97+
98+
# Rope project settings
99+
.ropeproject
100+
101+
# mkdocs documentation
102+
/site
103+
104+
# mypy
105+
.mypy_cache/
106+
107+
# Bundler
108+
Gemfile.lock
109+
110+
# copied `.md` files used for conversion to `.rst` using `m2r`
111+
docs/*.md
112+
113+
# Vim
114+
*.sw?
115+
116+
## Collected when centralising formulas (check and sort)
117+
# `collectd-formula`
118+
.pytest_cache/
119+
/.idea/
120+
Dockerfile.*_*
121+
ignore/
122+
tmp/

.travis.yml

Lines changed: 11 additions & 18 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,6 @@
1+
# -*- coding: utf-8 -*-
2+
# vim: ft=yaml
3+
---
14
stages:
25
- test
36
- commitlint
@@ -7,26 +10,20 @@ stages:
710
sudo: required
811
cache: bundler
912
language: ruby
13+
dist: xenial
1014

1115
services:
1216
- docker
1317

1418
# Make sure the instances listed below match up with
1519
# the `platforms` defined in `kitchen.yml`
16-
# NOTE: Please try to select up to six instances that add some meaningful
17-
# testing of the formula's behaviour. If possible, try to refrain from
18-
# the classical "chosing all the instances because I want to test on
19-
# another/all distro/s" trap: it will just add time to the testing (see
20-
# the discussion on #121). As an example, the set chosen below covers
21-
# the most used distros families, systemd and non-systemd and the latest
22-
# three supported Saltstack versions with python2 and 3."
23-
# As for `kitchen.yml`, that should still contain all of the platforms,
24-
# to allow for comprehensive local testing
25-
# Ref: https://github.com/saltstack-formulas/template-formula/issues/118
26-
# Ref: https://github.com/saltstack-formulas/template-formula/issues/121
2720
env:
2821
matrix:
2922
- INSTANCE: default-debian-9-develop-py3
23+
# - INSTANCE: default-ubuntu-1804-develop-py3
24+
# - INSTANCE: default-centos-7-develop-py3
25+
# - INSTANCE: default-fedora-29-develop-py3
26+
# - INSTANCE: default-opensuse-leap-15-develop-py3
3027
- INSTANCE: default-debian-9-2019-2-py3
3128
- INSTANCE: default-ubuntu-1804-2019-2-py3
3229
- INSTANCE: default-centos-7-2019-2-py3
@@ -36,20 +33,16 @@ env:
3633
# - INSTANCE: default-ubuntu-1604-2018-3-py2
3734
# - INSTANCE: default-centos-7-2018-3-py2
3835
# Currently fails with "Cipher 'AES-256-GCM' mode not supported"
39-
#- INSTANCE: default-fedora-29-2018-3-py2
40-
# TODO: Use this when fixed instead of `opensuse-leap-42`
41-
# Ref: https://github.com/netmanagers/salt-image-builder/issues/2
42-
# - INSTANCE: default-opensuse-leap-15-2018-3-py2
43-
#- INSTANCE: default-opensuse-leap-42-2018-3-py2
36+
# - INSTANCE: default-fedora-29-2018-3-py2
37+
# - INSTANCE: default-opensuse-leap-42-2018-3-py2
4438
# - INSTANCE: default-debian-8-2017-7-py2
4539
# - INSTANCE: default-ubuntu-1604-2017-7-py2
46-
# TODO: Enable after improving the formula to work with other than `systemd`
4740
- INSTANCE: default-centos-6-2017-7-py2
4841
# - INSTANCE: default-fedora-28-2017-7-py2
4942
# - INSTANCE: default-opensuse-leap-42-2017-7-py2
5043

5144
script:
52-
- bundle exec kitchen verify ${INSTANCE}
45+
- bin/kitchen verify ${INSTANCE}
5346

5447
jobs:
5548
include:

docs/CONTRIBUTING.rst

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -154,6 +154,6 @@ An example of that:
154154
...
155155
156156
BREAKING CHANGE: With the removal of all of the `.sls` files under
157-
`openvpn/package`, this formula no longer supports the installation of
157+
`template package`, this formula no longer supports the installation of
158158
packages.
159159

kitchen.yml

Lines changed: 18 additions & 23 deletions
Original file line numberDiff line numberDiff line change
@@ -44,7 +44,7 @@ platforms:
4444
- sh bootstrap-salt.sh -XdPbfrq -x python3 git develop
4545
run_command: /usr/lib/systemd/systemd
4646

47-
## SALT 2019.2
47+
## SALT `2019.2`
4848
- name: debian-9-2019-2-py3
4949
driver:
5050
image: netmanagers/salt-2019.2-py3:debian-9
@@ -62,7 +62,7 @@ platforms:
6262
image: netmanagers/salt-2019.2-py3:opensuse-leap-15
6363
run_command: /usr/lib/systemd/systemd
6464

65-
## SALT 2018.3
65+
## SALT `2018.3`
6666
- name: debian-9-2018-3-py2
6767
driver:
6868
image: netmanagers/salt-2018.3-py2:debian-9
@@ -75,25 +75,18 @@ platforms:
7575
- name: fedora-29-2018-3-py2
7676
driver:
7777
image: netmanagers/salt-2018.3-py2:fedora-29
78-
# TODO: Use this when fixed instead of `opensuse-leap-42`
79-
# Ref: https://github.com/netmanagers/salt-image-builder/issues/2
80-
# - name: opensuse-leap-15-2018-3-py2
81-
# driver:
82-
# image: netmanagers/salt-2018.3-py2:opensuse-leap-15
83-
# run_command: /usr/lib/systemd/systemd
8478
- name: opensuse-leap-42-2018-3-py2
8579
driver:
8680
image: netmanagers/salt-2018.3-py2:opensuse-leap-42
8781
run_command: /usr/lib/systemd/systemd
8882

89-
## SALT 2017.7
83+
## SALT `2017.7`
9084
- name: debian-8-2017-7-py2
9185
driver:
9286
image: netmanagers/salt-2017.7-py2:debian-8
9387
- name: ubuntu-1604-2017-7-py2
9488
driver:
9589
image: netmanagers/salt-2017.7-py2:ubuntu-16.04
96-
# TODO: Modify the formula to work for non-`systemd` platforms
9790
- name: centos-6-2017-7-py2
9891
driver:
9992
image: netmanagers/salt-2017.7-py2:centos-6
@@ -115,17 +108,6 @@ provisioner:
115108
salt_copy_filter:
116109
- .kitchen
117110
- .git
118-
state_top:
119-
base:
120-
'*':
121-
- openvpn.config
122-
pillars:
123-
top.sls:
124-
base:
125-
'*':
126-
- openvpn
127-
pillars_from_files:
128-
openvpn.sls: test/integration/repositories/pillars.sls
129111

130112
verifier:
131113
# https://www.inspec.io/
@@ -134,8 +116,21 @@ verifier:
134116
# cli, documentation, html, progress, json, json-min, json-rspec, junit
135117
reporter:
136118
- cli
137-
inspec_tests:
138-
- path: test/integration/default
139119

140120
suites:
141121
- name: default
122+
provisioner:
123+
state_top:
124+
base:
125+
'*':
126+
- openvpn.config
127+
pillars:
128+
top.sls:
129+
base:
130+
'*':
131+
- openvpn
132+
pillars_from_files:
133+
openvpn.sls: test/integration/repositories/pillars.sls
134+
verifier:
135+
inspec_tests:
136+
- path: test/integration/default

test/integration/default/README.md

Lines changed: 50 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,50 @@
1+
# InSpec Profile: `default`
2+
3+
This shows the implementation of the `default` InSpec [profile](https://github.com/inspec/inspec/blob/master/docs/profiles.md).
4+
5+
## Verify a profile
6+
7+
InSpec ships with built-in features to verify a profile structure.
8+
9+
```bash
10+
$ inspec check default
11+
Summary
12+
-------
13+
Location: default
14+
Profile: profile
15+
Controls: 4
16+
Timestamp: 2019-06-24T23:09:01+00:00
17+
Valid: true
18+
19+
Errors
20+
------
21+
22+
Warnings
23+
--------
24+
```
25+
26+
## Execute a profile
27+
28+
To run all **supported** controls on a local machine use `inspec exec /path/to/profile`.
29+
30+
```bash
31+
$ inspec exec default
32+
..
33+
34+
Finished in 0.0025 seconds (files took 0.12449 seconds to load)
35+
8 examples, 0 failures
36+
```
37+
38+
## Execute a specific control from a profile
39+
40+
To run one control from the profile use `inspec exec /path/to/profile --controls name`.
41+
42+
```bash
43+
$ inspec exec default --controls package
44+
.
45+
46+
Finished in 0.0025 seconds (files took 0.12449 seconds to load)
47+
1 examples, 0 failures
48+
```
49+
50+
See an [example control here](https://github.com/inspec/inspec/blob/master/examples/profile/controls/example.rb).
Lines changed: 11 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,14 @@
1-
name: openvpn
2-
title: OpenVPN Formula
3-
maintainer: alxwr
1+
name: default
2+
title: openvpn formula
3+
maintainer: SaltStack Formulas
44
license: Apache-2.0
55
summary: Verify that the openvpn formula is setup and configured correctly
66
supports:
7-
- os-name: debian
8-
- os-name: ubuntu
9-
- os-name: centos
10-
- os-name: fedora
11-
- os-name: opensuse
12-
- os-name: suse
7+
- platform-name: debian
8+
- platform-name: ubuntu
9+
- platform-name: centos
10+
- platform-name: fedora
11+
- platform-name: opensuse
12+
- platform-name: suse
13+
- platform-name: freebsd
14+
- platform-name: amazon

0 commit comments

Comments
 (0)