Merge pull request #195 from baby-gnu/ci/force-hostname

test(inspec): use static hostname in mapdata
This commit is contained in:
Imran Iqbal 2020-09-09 12:41:22 +01:00 committed by GitHub
commit cf9abf5e5a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
19 changed files with 25 additions and 59 deletions

View File

@ -149,6 +149,8 @@ verifier:
suites: suites:
- name: default - name: default
driver:
hostname: example.net
provisioner: provisioner:
state_top: state_top:
base: base:

View File

@ -1,12 +1,7 @@
# frozen_string_literal: true # frozen_string_literal: true
# Replace per minion strings
replacement = {
hostname: system.hostname
}
mapdata_file = "_mapdata/#{system.platform[:finger].split('.').first}.yaml" mapdata_file = "_mapdata/#{system.platform[:finger].split('.').first}.yaml"
mapdata_dump = inspec.profile.file(mapdata_file) % replacement mapdata_dump = inspec.profile.file(mapdata_file)
control '`map.jinja` YAML dump' do control '`map.jinja` YAML dump' do
title 'should contain the lines' title 'should contain the lines'

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh-clients client: openssh-clients
client_version: latest client_version: latest

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh-clients client: openssh-clients
client_version: latest client_version: latest

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh client: openssh
client_version: latest client_version: latest

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh-clients client: openssh-clients
client_version: latest client_version: latest

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh-clients client: openssh-clients
client_version: latest client_version: latest

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh-clients client: openssh-clients
client_version: latest client_version: latest

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh-client client: openssh-client
client_version: latest client_version: latest

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh-client client: openssh-client
client_version: latest client_version: latest

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh-clients client: openssh-clients
client_version: latest client_version: latest

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh-clients client: openssh-clients
client_version: latest client_version: latest

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh client: openssh
client_version: latest client_version: latest

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh-client client: openssh-client
client_version: latest client_version: latest

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh-client client: openssh-client
client_version: latest client_version: latest

View File

@ -42,7 +42,7 @@ openssh:
present: false present: false
banner: /etc/ssh/banner banner: /etc/ssh/banner
banner_src: banner banner_src: banner
banner_string: 'Welcome to %{hostname}! banner_string: 'Welcome to example.net!
' '
client: openssh-client client: openssh-client
client_version: latest client_version: latest

View File

@ -8,13 +8,12 @@ It's goal is to share the libraries between all profiles.
### `system` ### `system`
The `system` library provides easy access to system dependents informations: The `system` library provides easy access to system dependent information:
- `system.hostname`: return the result of `hostname -s` or `hostnamectl --static` based on the availability of each commans - `system.platform`: based on `inspec.platform`, modify to values that are more consistent from a SaltStack perspective
- `system.platform`: take `inspec.platform` and mangle things a bit to be useful - `system.platform[:family]` provide a family name for Arch
- `system.platform[:family]` provides a family name for Arch
- `system.platform[:name]` modify `amazon` to `amazonlinux` - `system.platform[:name]` modify `amazon` to `amazonlinux`
- `system.platform[:release]` tweak for Arch and Amazon Linux: - `system.platform[:release]` tweak Arch and Amazon Linux:
- `Arch` is always `base-later` - `Arch` is always `base-latest`
- `Amazon Linux` release `2018` became `1` - `Amazon Linux` release `2018` is resolved as `1`
- `system.platform[:finger]` is just the concatenation of the name and the first release number (except for Ubuntu which gives `20.04` for example) - `system.platform[:finger]` is the concatenation of the name and the major release number (except for Ubuntu, which gives `ubuntu-20.04` for example)

View File

@ -1,7 +1,7 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
# vim: ft=yaml # vim: ft=yaml
--- ---
name: shared name: share
title: InSpec shared resources title: InSpec shared resources
maintainer: SaltStack Formulas maintainer: SaltStack Formulas
license: Apache-2.0 license: Apache-2.0

View File

@ -4,47 +4,17 @@
# Author: Daniel Dehennin <daniel.dehennin@ac-dijon.fr> # Author: Daniel Dehennin <daniel.dehennin@ac-dijon.fr>
# Copyright (C) 2020 Daniel Dehennin <daniel.dehennin@ac-dijon.fr> # Copyright (C) 2020 Daniel Dehennin <daniel.dehennin@ac-dijon.fr>
HOSTNAME_CMDS = %w[hostname hostnamectl].freeze
HOSTNAME_CMDS_OPT = {
'hostname' => '-s',
'hostnamectl' => '--static'
}.freeze
class SystemResource < Inspec.resource(1) class SystemResource < Inspec.resource(1)
name 'system' name 'system'
attr_reader :platform attr_reader :platform
attr_reader :hostname
def initialize def initialize
@platform = build_platform @platform = build_platform
@hostname = found_hostname
end end
private private
def found_hostname
cmd = guess_hostname_cmd
unless cmd.exit_status.zero?
raise Inspec::Exceptions::ResourceSkipped,
"Error running '#{cmd}': #{cmd.stderr}"
end
cmd.stdout.chomp
end
def guess_hostname_cmd
HOSTNAME_CMDS.each do |cmd|
if inspec.command(cmd).exist?
return inspec.command("#{cmd} #{HOSTNAME_CMDS_OPT[cmd]}")
end
end
raise Inspec::Exceptions::ResourceSkipped,
"Error: #{@platform[:finger]}} has none of #{HOSTNAME_CMDS.join(', ')}"
end
def build_platform def build_platform
{ {
family: build_platform_family, family: build_platform_family,