refactor(map): use top-level values:
key in map.jinja
dumps
* Semi-automated using https://github.com/myii/ssf-formula/pull/284
This commit is contained in:
parent
f941871f0b
commit
37597e5b12
@ -1,9 +1,9 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# {{ grains.get('osfinger', grains.os) }}
|
# {{ grains.get("osfinger", grains.os) }}
|
||||||
---
|
---
|
||||||
{#- use salt.slsutil.serialize to avoid encoding errors on some platforms #}
|
{#- use salt.slsutil.serialize to avoid encoding errors on some platforms #}
|
||||||
{{ salt['slsutil.serialize'](
|
{{ salt["slsutil.serialize"](
|
||||||
'yaml',
|
"yaml",
|
||||||
map,
|
map,
|
||||||
default_flow_style=False,
|
default_flow_style=False,
|
||||||
allow_unicode=True,
|
allow_unicode=True,
|
||||||
|
@ -2,13 +2,16 @@
|
|||||||
# vim: ft=sls
|
# vim: ft=sls
|
||||||
---
|
---
|
||||||
{#- Get the `tplroot` from `tpldir` #}
|
{#- Get the `tplroot` from `tpldir` #}
|
||||||
{%- set tplroot = tpldir.split('/')[0] %}
|
{%- set tplroot = tpldir.split("/")[0] %}
|
||||||
{%- from tplroot ~ "/map.jinja" import mapdata with context %}
|
{%- from tplroot ~ "/map.jinja" import mapdata with context %}
|
||||||
|
|
||||||
{%- do salt['log.debug']('### MAP.JINJA DUMP ###\n' ~ mapdata | yaml(False)) %}
|
{%- set _mapdata = {
|
||||||
|
"values": mapdata,
|
||||||
|
} %}
|
||||||
|
{%- do salt["log.debug"]("### MAP.JINJA DUMP ###\n" ~ _mapdata | yaml(False)) %}
|
||||||
|
|
||||||
{%- set output_dir = '/temp' if grains.os_family == 'Windows' else '/tmp' %}
|
{%- set output_dir = "/temp" if grains.os_family == "Windows" else "/tmp" %}
|
||||||
{%- set output_file = output_dir ~ '/salt_mapdata_dump.yaml' %}
|
{%- set output_file = output_dir ~ "/salt_mapdata_dump.yaml" %}
|
||||||
|
|
||||||
{{ tplroot }}-mapdata-dump:
|
{{ tplroot }}-mapdata-dump:
|
||||||
file.managed:
|
file.managed:
|
||||||
@ -16,4 +19,4 @@
|
|||||||
- source: salt://{{ tplroot }}/_mapdata/_mapdata.jinja
|
- source: salt://{{ tplroot }}/_mapdata/_mapdata.jinja
|
||||||
- template: jinja
|
- template: jinja
|
||||||
- context:
|
- context:
|
||||||
map: {{ mapdata | yaml }}
|
map: {{ _mapdata | yaml }}
|
||||||
|
@ -5,19 +5,43 @@ require 'yaml'
|
|||||||
control '`map.jinja` YAML dump' do
|
control '`map.jinja` YAML dump' do
|
||||||
title 'should match the comparison file'
|
title 'should match the comparison file'
|
||||||
|
|
||||||
|
### Method
|
||||||
|
# The steps below for each file appear convoluted but they are both required
|
||||||
|
# and similar in nature:
|
||||||
|
# 1. The earliest method was to simply compare the files textually but this often
|
||||||
|
# led to false positives due to inconsistencies (e.g. spacing, ordering)
|
||||||
|
# 2. The next method was to load the files back into YAML structures and then
|
||||||
|
# compare but InSpec provided block diffs this way, unusable by end users
|
||||||
|
# 3. The final step was to dump the YAML structures back into a string to use
|
||||||
|
# for the comparison; this both worked and provided human-friendly diffs
|
||||||
|
|
||||||
|
### Comparison file for the specific platform
|
||||||
|
### Static, adjusted as part of code contributions, as map data is changed
|
||||||
# Strip the `platform[:finger]` version number down to the "OS major release"
|
# Strip the `platform[:finger]` version number down to the "OS major release"
|
||||||
mapdata_file = "_mapdata/#{system.platform[:finger].split('.').first}.yaml"
|
platform_finger = system.platform[:finger].split('.').first.to_s
|
||||||
|
# Use that to set the path to the file (relative to the InSpec suite directory)
|
||||||
|
mapdata_file_path = "_mapdata/#{platform_finger}.yaml"
|
||||||
|
# Load the mapdata from profile, into a YAML structure
|
||||||
|
# https://docs.chef.io/inspec/profiles/#profile-files
|
||||||
|
mapdata_file_yaml = YAML.safe_load(inspec.profile.file(mapdata_file_path))
|
||||||
|
# Dump the YAML back into a string for comparison
|
||||||
|
mapdata_file_dump = YAML.dump(mapdata_file_yaml)
|
||||||
|
|
||||||
# Load the mapdata from profile https://docs.chef.io/inspec/profiles/#profile-files
|
### Output file produced by running the `_mapdata` state
|
||||||
mapdata_dump = YAML.safe_load(inspec.profile.file(mapdata_file))
|
### Dynamic, generated during Kitchen's `converge` phase
|
||||||
|
# Derive the location of the dumped mapdata (differs for Windows)
|
||||||
# Derive the location of the dumped mapdata
|
|
||||||
output_dir = platform[:family] == 'windows' ? '/temp' : '/tmp'
|
output_dir = platform[:family] == 'windows' ? '/temp' : '/tmp'
|
||||||
output_file = "#{output_dir}/salt_mapdata_dump.yaml"
|
# Use that to set the path to the file (absolute path, i.e. within the container)
|
||||||
|
output_file_path = "#{output_dir}/salt_mapdata_dump.yaml"
|
||||||
|
# Load the output into a YAML structure using InSpec's `yaml` resource
|
||||||
|
# https://github.com/inspec/inspec/blob/49b7d10/lib/inspec/resources/yaml.rb#L29
|
||||||
|
output_file_yaml = yaml(output_file_path).params
|
||||||
|
# Dump the YAML back into a string for comparison
|
||||||
|
output_file_dump = YAML.dump(output_file_yaml)
|
||||||
|
|
||||||
describe 'File content' do
|
describe 'File content' do
|
||||||
it 'should match profile map data exactly' do
|
it 'should match profile map data exactly' do
|
||||||
expect(yaml(output_file).params).to eq(mapdata_dump)
|
expect(output_file_dump).to eq(mapdata_file_dump)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# Amazon Linux AMI-2018
|
# Amazon Linux AMI-2018
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# Amazon Linux-2
|
# Amazon Linux-2
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# Arch
|
# Arch
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# CentOS-6
|
# CentOS-6
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# CentOS Linux-7
|
# CentOS Linux-7
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# CentOS Linux-8
|
# CentOS Linux-8
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# Debian-10
|
# Debian-10
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# Debian-9
|
# Debian-9
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# Fedora-31
|
# Fedora-31
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# Fedora-32
|
# Fedora-32
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# Leap-15
|
# Leap-15
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# Ubuntu-16.04
|
# Ubuntu-16.04
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# Ubuntu-18.04
|
# Ubuntu-18.04
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
# yamllint disable rule:indentation rule:line-length
|
# yamllint disable rule:indentation rule:line-length
|
||||||
# Ubuntu-20.04
|
# Ubuntu-20.04
|
||||||
---
|
---
|
||||||
|
values:
|
||||||
map_jinja:
|
map_jinja:
|
||||||
config_get_roots:
|
config_get_roots:
|
||||||
- openssh
|
- openssh
|
||||||
|
Loading…
Reference in New Issue
Block a user