Skip to content

Commit aa492c3

Browse files
authored
Merge pull request #275 from myii/ci/standardise-structure
chore: use `semantic-release` cross-formula standard structure
2 parents 5e631bf + 72ff82c commit aa492c3

File tree

9 files changed

+135
-43
lines changed

9 files changed

+135
-43
lines changed

.gitignore

Lines changed: 13 additions & 1 deletion
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
@@ -103,8 +104,19 @@ ENV/
103104
# mypy
104105
.mypy_cache/
105106

107+
# Bundler
108+
Gemfile.lock
109+
106110
# copied `.md` files used for conversion to `.rst` using `m2r`
107111
docs/*.md
108112

109113
# Vim
110-
*.sw[nop]
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: 5 additions & 5 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,6 +10,7 @@ stages:
710
sudo: required
811
cache: bundler
912
language: ruby
13+
dist: xenial
1014

1115
services:
1216
- docker
@@ -31,19 +35,15 @@ env:
3135
- INSTANCE: default-ubuntu-1604-2018-3-py2
3236
# - INSTANCE: default-centos-7-2018-3-py2
3337
# - INSTANCE: default-fedora-29-2018-3-py2
34-
# TODO: Use this when fixed instead of `opensuse-leap-42`
35-
# Ref: https://github.com/netmanagers/salt-image-builder/issues/2
36-
# - INSTANCE: default-opensuse-leap-15-2018-3-py2
3738
- INSTANCE: default-opensuse-leap-42-2018-3-py2
3839
# - INSTANCE: default-debian-8-2017-7-py2
3940
# - INSTANCE: default-ubuntu-1604-2017-7-py2
40-
# TODO: Enable after improving the formula to work with other than `systemd`
4141
- INSTANCE: default-centos-6-2017-7-py2
4242
# - INSTANCE: default-fedora-28-2017-7-py2
4343
# - INSTANCE: default-opensuse-leap-42-2017-7-py2
4444

4545
script:
46-
- bundle exec kitchen verify ${INSTANCE}
46+
- bin/kitchen verify ${INSTANCE}
4747

4848
jobs:
4949
include:

Gemfile

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3,3 +3,4 @@ source "https://rubygems.org"
33
gem 'kitchen-docker', '>= 2.9'
44
gem 'kitchen-salt', '>= 0.6.0'
55
gem 'kitchen-inspec', '>= 1.1'
6+

bin/kitchen

Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
#!/usr/bin/env ruby
2+
# frozen_string_literal: true
3+
4+
#
5+
# This file was generated by Bundler.
6+
#
7+
# The application 'kitchen' is installed as part of a gem, and
8+
# this file is here to facilitate running it.
9+
#
10+
11+
require "pathname"
12+
ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../../Gemfile",
13+
Pathname.new(__FILE__).realpath)
14+
15+
bundle_binstub = File.expand_path("../bundle", __FILE__)
16+
17+
if File.file?(bundle_binstub)
18+
if File.read(bundle_binstub, 300) =~ /This file was generated by Bundler/
19+
load(bundle_binstub)
20+
else
21+
abort("Your `bin/bundle` was not generated by Bundler, so this binstub cannot run.
22+
Replace `bin/bundle` by running `bundle binstubs bundler --force`, then run this command again.")
23+
end
24+
end
25+
26+
require "rubygems"
27+
require "bundler/setup"
28+
29+
load Gem.bin_path("test-kitchen", "kitchen")

docs/CONTRIBUTING.rst

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -156,3 +156,4 @@ An example of that:
156156
BREAKING CHANGE: With the removal of all of the `.sls` files under
157157
`template package`, this formula no longer supports the installation of
158158
packages.
159+

kitchen.yml

Lines changed: 18 additions & 22 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,18 +75,12 @@ 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
@@ -114,17 +108,6 @@ provisioner:
114108
salt_copy_filter:
115109
- .kitchen
116110
- .git
117-
state_top:
118-
base:
119-
'*':
120-
- postgres
121-
pillars:
122-
top.sls:
123-
base:
124-
'*':
125-
- postgres
126-
pillars_from_files:
127-
postgres.sls: test/salt/pillar/postgres.sls
128111

129112
verifier:
130113
# https://www.inspec.io/
@@ -133,8 +116,21 @@ verifier:
133116
# cli, documentation, html, progress, json, json-min, json-rspec, junit
134117
reporter:
135118
- cli
136-
inspec_tests:
137-
- path: test/integration/default
138119

139120
suites:
140121
- name: default
122+
provisioner:
123+
state_top:
124+
base:
125+
'*':
126+
- postgres
127+
pillars:
128+
top.sls:
129+
base:
130+
'*':
131+
- postgres
132+
pillars_from_files:
133+
postgres.sls: test/salt/pillar/postgres.sls
134+
verifier:
135+
inspec_tests:
136+
- path: test/integration/default

postgres/libtofs.jinja

Lines changed: 7 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -87,12 +87,13 @@
8787
{%- else %}
8888
{%- set fs_dir = salt['config.get'](tplroot ~ ':tofs:dirs:default', 'default') %}
8989
{%- endif %}
90-
{%- set url = '- salt://' ~ '/'.join([
91-
path_prefix_inc_ext,
92-
files_dir,
93-
fs_dir,
94-
src_file.lstrip('/')
95-
]) %}
90+
{%- set url = [
91+
'- salt:/',
92+
path_prefix_inc_ext.strip('/'),
93+
files_dir.strip('/'),
94+
fs_dir.strip('/'),
95+
src_file.strip('/'),
96+
] | select | join('/') %}
9697
{{ url | indent(indent_width, true) }}
9798
{%- endfor %}
9899
{%- endfor %}

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).

test/integration/default/inspec.yml

Lines changed: 11 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,14 @@
1-
name: postgres
2-
title: Postgres Formula
3-
maintainer: Your Name
1+
name: default
2+
title: postgres formula
3+
maintainer: SaltStack Formulas
44
license: Apache-2.0
55
summary: Verify that the postgres 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)