Skip to content

Commit fb18252

Browse files
authored
Merge pull request #93 from myii/ci/standardise-structure
chore: use `semantic-release` cross-formula standard structure
2 parents 6fa00be + e3cca62 commit fb18252

File tree

5 files changed

+94
-49
lines changed

5 files changed

+94
-49
lines changed

.gitignore

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -48,6 +48,7 @@ coverage.xml
4848
.kitchen
4949
.kitchen.local.yml
5050
kitchen.local.yml
51+
junit-*.xml
5152

5253
# Translations
5354
*.mo
@@ -111,3 +112,11 @@ docs/*.md
111112

112113
# Vim
113114
*.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: 5 additions & 16 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,23 +10,13 @@ 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
@@ -40,19 +33,15 @@ env:
4033
# - INSTANCE: default-ubuntu-1604-2018-3-py2
4134
# - INSTANCE: default-centos-7-2018-3-py2
4235
- INSTANCE: default-fedora-29-2018-3-py2
43-
# TODO: Use this when fixed instead of `opensuse-leap-42`
44-
# Ref: https://github.com/netmanagers/salt-image-builder/issues/2
45-
# - INSTANCE: default-opensuse-leap-15-2018-3-py2
4636
- INSTANCE: default-opensuse-leap-42-2018-3-py2
4737
# - INSTANCE: default-debian-8-2017-7-py2
4838
# - INSTANCE: default-ubuntu-1604-2017-7-py2
49-
# TODO: Enable after improving the formula to work with other than `systemd`
5039
- INSTANCE: default-centos-6-2017-7-py2
5140
# - INSTANCE: default-fedora-28-2017-7-py2
5241
# - INSTANCE: default-opensuse-leap-42-2017-7-py2
5342

5443
script:
55-
- bundle exec kitchen verify ${INSTANCE}
44+
- bin/kitchen verify ${INSTANCE}
5645

5746
jobs:
5847
include:

kitchen.yml

Lines changed: 19 additions & 24 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,18 +108,6 @@ provisioner:
115108
salt_copy_filter:
116109
- .kitchen
117110
- .git
118-
state_top:
119-
base:
120-
'*':
121-
- postfix
122-
- postfix.config
123-
pillars:
124-
top.sls:
125-
base:
126-
'*':
127-
- postfix
128-
pillars_from_files:
129-
postfix.sls: './test/salt/pillar/default.sls'
130111

131112
verifier:
132113
# https://www.inspec.io/
@@ -135,8 +116,22 @@ verifier:
135116
# cli, documentation, html, progress, json, json-min, json-rspec, junit
136117
reporter:
137118
- cli
138-
inspec_tests:
139-
- path: test/integration/default
140119

141120
suites:
142121
- name: default
122+
provisioner:
123+
state_top:
124+
base:
125+
'*':
126+
- postfix
127+
- postfix.config
128+
pillars:
129+
top.sls:
130+
base:
131+
'*':
132+
- postfix
133+
pillars_from_files:
134+
postfix.sls: test/salt/pillar/default.sls
135+
verifier:
136+
inspec_tests:
137+
- 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: postfix
2-
title: Postfix Formula
3-
maintainer: Saltstack Formulas
1+
name: default
2+
title: postfix formula
3+
maintainer: SaltStack Formulas
44
license: Apache-2.0
55
summary: Verify that the postfix 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)