From d75c13286cc96f829caea4be570832b551719e74 Mon Sep 17 00:00:00 2001 From: Ewoud Kohl van Wijngaarden Date: Fri, 6 Aug 2021 16:52:59 +0200 Subject: [PATCH 1/3] Move plugin specs to their own directory --- .../{foreman_proxy__plugin__abrt_spec.rb => plugin/abrt_spec.rb} | 0 .../{foreman_proxy__plugin__acd_spec.rb => plugin/acd_spec.rb} | 0 .../ansible_spec.rb} | 0 .../{foreman_proxy__plugin__chef__spec.rb => plugin/chef_spec.rb} | 0 .../container_gateway_spec.rb} | 0 .../dhcp__infoblox_spec.rb} | 0 .../dhcp__remote_isc_spec.rb} | 0 .../discovery_spec.rb} | 0 .../dns__infoblox_spec.rb} | 0 .../dns__powerdns_spec.rb} | 0 .../dns__route53_spec.rb} | 0 .../dynflow_spec.rb} | 0 .../monitoring__icinga2_spec.rb} | 0 .../monitoring__icingadirector_spec.rb} | 0 .../monitoring_spec.rb} | 0 .../omaha_spec.rb} | 0 .../openscap_spec.rb} | 0 .../{foreman_proxy__plugin__pulp_spec.rb => plugin/pulp_spec.rb} | 0 .../realm__ad_spec.rb} | 0 .../remote_execution__ssh_spec.rb} | 0 .../remote_execution__ssh_user_spec.rb} | 0 .../{foreman_proxy__plugin__salt_spec.rb => plugin/salt_spec.rb} | 0 .../shellhooks_spec.rb} | 0 23 files changed, 0 insertions(+), 0 deletions(-) rename spec/classes/{foreman_proxy__plugin__abrt_spec.rb => plugin/abrt_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__acd_spec.rb => plugin/acd_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__ansible_spec.rb => plugin/ansible_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__chef__spec.rb => plugin/chef_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__container_gateway_spec.rb => plugin/container_gateway_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__dhcp__infoblox_spec.rb => plugin/dhcp__infoblox_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__dhcp__remote_isc_spec.rb => plugin/dhcp__remote_isc_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__discovery_spec.rb => plugin/discovery_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__dns__infoblox_spec.rb => plugin/dns__infoblox_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__dns__powerdns_spec.rb => plugin/dns__powerdns_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__dns__route53_spec.rb => plugin/dns__route53_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__dynflow_spec.rb => plugin/dynflow_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__monitoring__icinga2_spec.rb => plugin/monitoring__icinga2_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__monitoring__icingadirector_spec.rb => plugin/monitoring__icingadirector_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__monitoring_spec.rb => plugin/monitoring_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__omaha_spec.rb => plugin/omaha_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__openscap_spec.rb => plugin/openscap_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__pulp_spec.rb => plugin/pulp_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__realm__ad_spec.rb => plugin/realm__ad_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__remote_execution__ssh_spec.rb => plugin/remote_execution__ssh_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__remote_execution__ssh_user_spec.rb => plugin/remote_execution__ssh_user_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__salt_spec.rb => plugin/salt_spec.rb} (100%) rename spec/classes/{foreman_proxy__plugin__shellhooks_spec.rb => plugin/shellhooks_spec.rb} (100%) diff --git a/spec/classes/foreman_proxy__plugin__abrt_spec.rb b/spec/classes/plugin/abrt_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__abrt_spec.rb rename to spec/classes/plugin/abrt_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__acd_spec.rb b/spec/classes/plugin/acd_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__acd_spec.rb rename to spec/classes/plugin/acd_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__ansible_spec.rb b/spec/classes/plugin/ansible_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__ansible_spec.rb rename to spec/classes/plugin/ansible_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__chef__spec.rb b/spec/classes/plugin/chef_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__chef__spec.rb rename to spec/classes/plugin/chef_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__container_gateway_spec.rb b/spec/classes/plugin/container_gateway_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__container_gateway_spec.rb rename to spec/classes/plugin/container_gateway_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__dhcp__infoblox_spec.rb b/spec/classes/plugin/dhcp__infoblox_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__dhcp__infoblox_spec.rb rename to spec/classes/plugin/dhcp__infoblox_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__dhcp__remote_isc_spec.rb b/spec/classes/plugin/dhcp__remote_isc_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__dhcp__remote_isc_spec.rb rename to spec/classes/plugin/dhcp__remote_isc_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__discovery_spec.rb b/spec/classes/plugin/discovery_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__discovery_spec.rb rename to spec/classes/plugin/discovery_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__dns__infoblox_spec.rb b/spec/classes/plugin/dns__infoblox_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__dns__infoblox_spec.rb rename to spec/classes/plugin/dns__infoblox_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__dns__powerdns_spec.rb b/spec/classes/plugin/dns__powerdns_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__dns__powerdns_spec.rb rename to spec/classes/plugin/dns__powerdns_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__dns__route53_spec.rb b/spec/classes/plugin/dns__route53_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__dns__route53_spec.rb rename to spec/classes/plugin/dns__route53_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__dynflow_spec.rb b/spec/classes/plugin/dynflow_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__dynflow_spec.rb rename to spec/classes/plugin/dynflow_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__monitoring__icinga2_spec.rb b/spec/classes/plugin/monitoring__icinga2_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__monitoring__icinga2_spec.rb rename to spec/classes/plugin/monitoring__icinga2_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__monitoring__icingadirector_spec.rb b/spec/classes/plugin/monitoring__icingadirector_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__monitoring__icingadirector_spec.rb rename to spec/classes/plugin/monitoring__icingadirector_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__monitoring_spec.rb b/spec/classes/plugin/monitoring_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__monitoring_spec.rb rename to spec/classes/plugin/monitoring_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__omaha_spec.rb b/spec/classes/plugin/omaha_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__omaha_spec.rb rename to spec/classes/plugin/omaha_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__openscap_spec.rb b/spec/classes/plugin/openscap_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__openscap_spec.rb rename to spec/classes/plugin/openscap_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__pulp_spec.rb b/spec/classes/plugin/pulp_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__pulp_spec.rb rename to spec/classes/plugin/pulp_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__realm__ad_spec.rb b/spec/classes/plugin/realm__ad_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__realm__ad_spec.rb rename to spec/classes/plugin/realm__ad_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__remote_execution__ssh_spec.rb b/spec/classes/plugin/remote_execution__ssh_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__remote_execution__ssh_spec.rb rename to spec/classes/plugin/remote_execution__ssh_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__remote_execution__ssh_user_spec.rb b/spec/classes/plugin/remote_execution__ssh_user_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__remote_execution__ssh_user_spec.rb rename to spec/classes/plugin/remote_execution__ssh_user_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__salt_spec.rb b/spec/classes/plugin/salt_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__salt_spec.rb rename to spec/classes/plugin/salt_spec.rb diff --git a/spec/classes/foreman_proxy__plugin__shellhooks_spec.rb b/spec/classes/plugin/shellhooks_spec.rb similarity index 100% rename from spec/classes/foreman_proxy__plugin__shellhooks_spec.rb rename to spec/classes/plugin/shellhooks_spec.rb From 3acaaf433f6a306cce52dda4a7c9c6d188bf3f9b Mon Sep 17 00:00:00 2001 From: Ewoud Kohl van Wijngaarden Date: Fri, 6 Aug 2021 17:09:33 +0200 Subject: [PATCH 2/3] Introduce a shared example for plugin testing --- spec/classes/plugin/abrt_spec.rb | 19 ++----- spec/classes/plugin/acd_spec.rb | 8 +-- spec/classes/plugin/ansible_spec.rb | 37 ++++++++------ spec/classes/plugin/chef_spec.rb | 51 ++++++++++--------- spec/classes/plugin/container_gateway_spec.rb | 35 +++++++------ spec/support/plugin.rb | 47 +++++++++++++++++ 6 files changed, 122 insertions(+), 75 deletions(-) diff --git a/spec/classes/plugin/abrt_spec.rb b/spec/classes/plugin/abrt_spec.rb index f4771d3f..c1b1f9e4 100644 --- a/spec/classes/plugin/abrt_spec.rb +++ b/spec/classes/plugin/abrt_spec.rb @@ -7,16 +7,8 @@ let(:pre_condition) { 'include foreman_proxy' } describe 'with default settings' do - it { should contain_foreman_proxy__plugin__module('abrt') } - it 'should configure abrt.yml' do - should contain_file('/etc/foreman-proxy/settings.d/abrt.yml'). - with({ - :ensure => 'file', - :owner => 'root', - :group => 'foreman-proxy', - :mode => '0640', - :content => /:enabled: https/ - }) + include_examples 'a plugin with a settings file', 'abrt' do + let(:expected_config) { /:enabled: https/ } end end @@ -26,10 +18,9 @@ :faf_server_ssl_key => '/faf_key.pem', } end - it 'should set server_ssl_cert and _key' do - should contain_file('/etc/foreman-proxy/settings.d/abrt.yml'). - with_content(%r{^:server_ssl_cert:\s+/faf_cert.pem$}). - with_content(%r{^:server_ssl_key:\s+/faf_key.pem$}) + include_examples 'a plugin with a settings file', 'abrt' do + # TODO: this is weaker than it was + let(:expected_config) { %r{:server_ssl_(cert|key): /faf_\1\.pem} } end end end diff --git a/spec/classes/plugin/acd_spec.rb b/spec/classes/plugin/acd_spec.rb index c8eec325..43340f6d 100644 --- a/spec/classes/plugin/acd_spec.rb +++ b/spec/classes/plugin/acd_spec.rb @@ -7,12 +7,8 @@ let(:pre_condition) { 'include foreman_proxy' } describe 'with default settings' do - it { should contain_foreman_proxy__plugin__module('acd') } - it 'acd.yml should contain the correct configuration' do - verify_exact_contents(catalogue, '/etc/foreman-proxy/settings.d/acd.yml', [ - '---', - ':enabled: https', - ]) + include_examples 'a plugin with a settings file', 'acd' do + let(:expected_config) { "---\n:enabled: https\n" } end end end diff --git a/spec/classes/plugin/ansible_spec.rb b/spec/classes/plugin/ansible_spec.rb index 2ce1652e..a2481a73 100644 --- a/spec/classes/plugin/ansible_spec.rb +++ b/spec/classes/plugin/ansible_spec.rb @@ -8,7 +8,17 @@ describe 'with default settings' do it { should contain_class('foreman_proxy::plugin::dynflow') } - it { should contain_foreman_proxy__plugin__module('ansible') } + + include_examples 'a plugin with a settings file', 'ansible' do + let(:expected_config) do + <<~CONFIG + --- + :enabled: https + :ansible_dir: /usr/share/foreman-proxy + :working_dir: /tmp + CONFIG + end + end case os when 'debian-10-x86_64' @@ -28,13 +38,6 @@ it { should contain_package('ansible-runner').with_ensure('installed') } end - - it 'should configure ansible.yml' do - should contain_file('/etc/foreman-proxy/settings.d/ansible.yml'). - with_content(/:enabled: https/). - with_content(%r{:ansible_dir: /usr/share/foreman-proxy}) - end - it 'should configure ansible.cfg' do callback = facts[:os]['family'] == 'RedHat' ? 'theforeman.foreman.foreman' : 'foreman' verify_exact_contents(catalogue, '/etc/foreman-proxy/ansible.cfg', [ @@ -70,6 +73,17 @@ it { should contain_class('foreman_proxy::plugin::dynflow') } + include_examples 'a plugin with a settings file', 'ansible' do + let(:expected_config) do + <<~CONFIG + --- + :enabled: https + :ansible_dir: /etc/ansible-test + :working_dir: /tmp/ansible + CONFIG + end + end + case os when 'debian-10-x86_64' it { should_not contain_apt__source('ansible-runner') } @@ -79,13 +93,6 @@ it { should contain_package('ansible-runner').with_ensure('installed') } end - it 'should configure ansible.yml' do - should contain_file('/etc/foreman-proxy/settings.d/ansible.yml'). - with_content(/:enabled: https/). - with_content(%r{:ansible_dir: /etc/ansible-test}). - with_content(%r{:working_dir: /tmp/ansible}) - end - it 'should configure ansible.cfg' do callback = facts[:os]['family'] == 'RedHat' ? 'theforeman.foreman.foreman' : 'foreman' verify_exact_contents(catalogue, '/etc/foreman-proxy/ansible.cfg', [ diff --git a/spec/classes/plugin/chef_spec.rb b/spec/classes/plugin/chef_spec.rb index a9bd2e0e..db48f686 100644 --- a/spec/classes/plugin/chef_spec.rb +++ b/spec/classes/plugin/chef_spec.rb @@ -13,23 +13,29 @@ } end - it { should compile.with_all_deps } - - it 'should call the plugin' do - should contain_foreman_proxy__plugin__module('chef').with_enabled(true).with_listen_on('https') - end - - it 'should install configuration file' do - should contain_foreman_proxy__settings_file('chef') - verify_exact_contents(catalogue, '/etc/foreman-proxy/settings.d/chef.yml', [ - '---', - ':enabled: https', - ':chef_authenticate_nodes: true', - ':chef_server_url: https://foo.example.com', - ':chef_smartproxy_clientname: foo.example.com', - ':chef_smartproxy_privatekey: /etc/chef/client.pem', - ':chef_ssl_verify: true' - ]) + include_examples 'a plugin with a settings file', 'chef' do + let(:expected_config) do + <<~CONFIG + --- + :enabled: https + :chef_authenticate_nodes: true + :chef_server_url: https://foo.example.com + # smart-proxy client node needs to have some admin right on chef-server + # in order to retrive all nodes public keys + # e.g. 'host.example.net' + :chef_smartproxy_clientname: foo.example.com + # e.g. /etc/chef/client.pem + :chef_smartproxy_privatekey: /etc/chef/client.pem + + # turning of chef_ssl_verify is not recommended as it turn off authentication + # you can try set path to chef server certificate by chef_ssl_pem_file + # before setting chef_ssl_verify to false + # note that chef_ssl_pem_file must contain both private key and certificate + # because chef-api 0.5 requires it + :chef_ssl_verify: true + # :chef_ssl_pem_file: /path + CONFIG + end end end @@ -40,14 +46,9 @@ } end - it { should compile.with_all_deps } - - it 'should call the plugin' do - should contain_foreman_proxy__plugin__module('chef').with_enabled(false) - end - - it 'should install configuration file' do - should contain_file('/etc/foreman-proxy/settings.d/chef.yml').with_content(/:enabled: false/) + include_examples 'a plugin with a settings file', 'chef' do + let(:expected_config) { /:enabled: false/ } + let(:expected_enabled) { false } end end end diff --git a/spec/classes/plugin/container_gateway_spec.rb b/spec/classes/plugin/container_gateway_spec.rb index 82281db0..ad19bd4f 100644 --- a/spec/classes/plugin/container_gateway_spec.rb +++ b/spec/classes/plugin/container_gateway_spec.rb @@ -7,14 +7,16 @@ let(:pre_condition) { 'include foreman_proxy' } describe 'with default settings' do - it { should contain_foreman_proxy__plugin__module('container_gateway') } - it 'container_gateway.yml should contain the correct configuration' do - verify_exact_contents(catalogue, '/etc/foreman-proxy/settings.d/container_gateway.yml', [ - '---', - ':enabled: https', - ":pulp_endpoint: https://#{facts[:fqdn]}", - ':sqlite_db_path: /var/lib/foreman-proxy/smart_proxy_container_gateway.db' - ]) + include_examples 'a plugin with a settings file', 'container_gateway' do + let(:expected_config) do + <<~CONFIG + --- + # Container Gateway for Katello + :enabled: https + :pulp_endpoint: https://#{facts[:fqdn]} + :sqlite_db_path: /var/lib/foreman-proxy/smart_proxy_container_gateway.db + CONFIG + end end end @@ -24,13 +26,16 @@ :sqlite_db_path => '/dev/null.db', } end - it 'container_gateway.yml should contain the correct configuration' do - verify_exact_contents(catalogue, '/etc/foreman-proxy/settings.d/container_gateway.yml', [ - '---', - ':enabled: https', - ':pulp_endpoint: https://test.example.com', - ':sqlite_db_path: /dev/null.db' - ]) + include_examples 'a plugin with a settings file', 'container_gateway' do + let(:expected_config) do + <<~CONFIG + --- + # Container Gateway for Katello + :enabled: https + :pulp_endpoint: https://test.example.com + :sqlite_db_path: /dev/null.db + CONFIG + end end end end diff --git a/spec/support/plugin.rb b/spec/support/plugin.rb index 3df2b5c0..25a781cc 100644 --- a/spec/support/plugin.rb +++ b/spec/support/plugin.rb @@ -11,3 +11,50 @@ def on_plugin_os ] on_supported_os(supported_os: supported_os) end + +def describe_plugin(name, &block) + supported_os = [ + { + 'operatingsystem' => 'RedHat', + 'operatingsystemrelease' => ['7'], + }, + { + 'operatingsystem' => 'Debian', + 'operatingsystemrelease' => ['10'], + }, + ] + + describe name do + on_supported_os(supported_os: supported_os).each do |os, os_facts| + context("on #{os}") do + let(:facts) { os_facts } + let(:pre_condition) { 'include foreman_proxy' } + + class_exec(&block) + end + end + end +end + +shared_examples 'a plugin with a settings file' do |plugin| + let(:expected_enabled) { true } + let(:expected_lisen_on) { 'https' } + + it { is_expected.to compile.with_all_deps } + + it 'contains the plugin' do + is_expected.to contain_foreman_proxy__plugin__module(plugin) + .with_enabled(expected_enabled) + .with_listen_on('https') + end + + it 'includes a configuration file' do + is_expected.to contain_foreman_proxy__settings_file(plugin) + is_expected.to contain_file("/etc/foreman-proxy/settings.d/#{plugin}.yml") + .with_ensure('file') + .with_owner('root') + .with_group('foreman-proxy') + .with_mode('0640') + .with_content(expected_config) + end +end From cfb5b8ac986cbdd42a8c05e8862b573e68493f0d Mon Sep 17 00:00:00 2001 From: Ewoud Kohl van Wijngaarden Date: Fri, 6 Aug 2021 17:24:38 +0200 Subject: [PATCH 3/3] Add a describe_plugin helper This removes a lot of the boiler plate in our plugin tests. --- spec/classes/plugin/abrt_spec.rb | 35 ++- spec/classes/plugin/acd_spec.rb | 15 +- spec/classes/plugin/ansible_spec.rb | 227 +++++++++--------- spec/classes/plugin/chef_spec.rb | 85 +++---- spec/classes/plugin/container_gateway_spec.rb | 61 +++-- spec/support/plugin.rb | 13 +- 6 files changed, 195 insertions(+), 241 deletions(-) diff --git a/spec/classes/plugin/abrt_spec.rb b/spec/classes/plugin/abrt_spec.rb index c1b1f9e4..a281255a 100644 --- a/spec/classes/plugin/abrt_spec.rb +++ b/spec/classes/plugin/abrt_spec.rb @@ -1,28 +1,21 @@ require 'spec_helper' -describe 'foreman_proxy::plugin::abrt' do - on_plugin_os.each do |os, os_facts| - context "on #{os}" do - let(:facts) { os_facts } - let(:pre_condition) { 'include foreman_proxy' } - - describe 'with default settings' do - include_examples 'a plugin with a settings file', 'abrt' do - let(:expected_config) { /:enabled: https/ } - end - end +describe_plugin 'foreman_proxy::plugin::abrt' do + describe 'with default settings' do + include_examples 'a plugin with a settings file', 'abrt' do + let(:expected_config) { /:enabled: https/ } + end + end - describe 'with faf_ssl_* set' do - let :params do { - :faf_server_ssl_cert => '/faf_cert.pem', - :faf_server_ssl_key => '/faf_key.pem', - } end + describe 'with faf_ssl_* set' do + let :params do { + :faf_server_ssl_cert => '/faf_cert.pem', + :faf_server_ssl_key => '/faf_key.pem', + } end - include_examples 'a plugin with a settings file', 'abrt' do - # TODO: this is weaker than it was - let(:expected_config) { %r{:server_ssl_(cert|key): /faf_\1\.pem} } - end - end + include_examples 'a plugin with a settings file', 'abrt' do + # TODO: this is weaker than it was + let(:expected_config) { %r{:server_ssl_(cert|key): /faf_\1\.pem} } end end end diff --git a/spec/classes/plugin/acd_spec.rb b/spec/classes/plugin/acd_spec.rb index 43340f6d..9cdb59ec 100644 --- a/spec/classes/plugin/acd_spec.rb +++ b/spec/classes/plugin/acd_spec.rb @@ -1,16 +1,9 @@ require 'spec_helper' -describe 'foreman_proxy::plugin::acd' do - on_plugin_os.each do |os, os_facts| - context "on #{os}" do - let(:facts) { os_facts } - let(:pre_condition) { 'include foreman_proxy' } - - describe 'with default settings' do - include_examples 'a plugin with a settings file', 'acd' do - let(:expected_config) { "---\n:enabled: https\n" } - end - end +describe_plugin 'foreman_proxy::plugin::acd' do + describe 'with default settings' do + include_examples 'a plugin with a settings file', 'acd' do + let(:expected_config) { "---\n:enabled: https\n" } end end end diff --git a/spec/classes/plugin/ansible_spec.rb b/spec/classes/plugin/ansible_spec.rb index a2481a73..5f0721f0 100644 --- a/spec/classes/plugin/ansible_spec.rb +++ b/spec/classes/plugin/ansible_spec.rb @@ -1,132 +1,125 @@ require 'spec_helper' -describe 'foreman_proxy::plugin::ansible' do - on_plugin_os.each do |os, os_facts| - context "on #{os}" do - let(:facts) { os_facts } - let(:pre_condition) { 'include foreman_proxy' } +describe_plugin 'foreman_proxy::plugin::ansible' do + describe 'with default settings' do + it { should contain_class('foreman_proxy::plugin::dynflow') } - describe 'with default settings' do - it { should contain_class('foreman_proxy::plugin::dynflow') } - - include_examples 'a plugin with a settings file', 'ansible' do - let(:expected_config) do - <<~CONFIG - --- - :enabled: https - :ansible_dir: /usr/share/foreman-proxy - :working_dir: /tmp - CONFIG - end - end - - case os - when 'debian-10-x86_64' - it 'should cleanup old ansible-runner upstream repo' do - should contain_apt__source('ansible-runner').with_ensure('absent') - end - it { should contain_package('python3-ansible-runner').with_ensure('installed') } - when 'redhat-7-x86_64' - it 'should include ansible-runner upstream repo' do - should contain_yumrepo('ansible-runner') - .with_baseurl("https://releases.ansible.com/ansible-runner/rpm/epel-7-$basearch/") - .with_gpgcheck(true) - .with_gpgkey('https://releases.ansible.com/keys/RPM-GPG-KEY-ansible-release.pub') - .with_enabled('1') - .that_comes_before('Package[ansible-runner]') - end - it { should contain_package('ansible-runner').with_ensure('installed') } - end - - it 'should configure ansible.cfg' do - callback = facts[:os]['family'] == 'RedHat' ? 'theforeman.foreman.foreman' : 'foreman' - verify_exact_contents(catalogue, '/etc/foreman-proxy/ansible.cfg', [ - '[defaults]', - "callback_whitelist = #{callback}", - 'local_tmp = /tmp', - 'host_key_checking = False', - 'stdout_callback = yaml', - '[callback_foreman]', - 'url = https://foo.example.com', - 'ssl_key = /etc/puppetlabs/puppet/ssl/private_keys/foo.example.com.pem', - 'ssl_cert = /etc/puppetlabs/puppet/ssl/certs/foo.example.com.pem', - 'verify_certs = /etc/puppetlabs/puppet/ssl/certs/ca.pem', - 'roles_path = /etc/ansible/roles:/usr/share/ansible/roles', - 'collections_paths = /etc/ansible/collections:/usr/share/ansible/collections', - '[ssh_connection]', - 'ssh_args = -o ProxyCommand=none -C -o ControlMaster=auto -o ControlPersist=60s', - ]) - end + include_examples 'a plugin with a settings file', 'ansible' do + let(:expected_config) do + <<~CONFIG + --- + :enabled: https + :ansible_dir: /usr/share/foreman-proxy + :working_dir: /tmp + CONFIG end + end - describe 'with override parameters' do - let :params do - { - enabled: true, - ansible_dir: '/etc/ansible-test', - working_dir: '/tmp/ansible', - host_key_checking: true, - stdout_callback: 'debug', - manage_runner_repo: false, - } - end + case os + when 'debian-10-x86_64' + it 'should cleanup old ansible-runner upstream repo' do + should contain_apt__source('ansible-runner').with_ensure('absent') + end + it { should contain_package('python3-ansible-runner').with_ensure('installed') } + when 'redhat-7-x86_64' + it 'should include ansible-runner upstream repo' do + should contain_yumrepo('ansible-runner') + .with_baseurl("https://releases.ansible.com/ansible-runner/rpm/epel-7-$basearch/") + .with_gpgcheck(true) + .with_gpgkey('https://releases.ansible.com/keys/RPM-GPG-KEY-ansible-release.pub') + .with_enabled('1') + .that_comes_before('Package[ansible-runner]') + end + it { should contain_package('ansible-runner').with_ensure('installed') } + end - it { should contain_class('foreman_proxy::plugin::dynflow') } + it 'should configure ansible.cfg' do + callback = facts[:os]['family'] == 'RedHat' ? 'theforeman.foreman.foreman' : 'foreman' + verify_exact_contents(catalogue, '/etc/foreman-proxy/ansible.cfg', [ + '[defaults]', + "callback_whitelist = #{callback}", + 'local_tmp = /tmp', + 'host_key_checking = False', + 'stdout_callback = yaml', + '[callback_foreman]', + 'url = https://foo.example.com', + 'ssl_key = /etc/puppetlabs/puppet/ssl/private_keys/foo.example.com.pem', + 'ssl_cert = /etc/puppetlabs/puppet/ssl/certs/foo.example.com.pem', + 'verify_certs = /etc/puppetlabs/puppet/ssl/certs/ca.pem', + 'roles_path = /etc/ansible/roles:/usr/share/ansible/roles', + 'collections_paths = /etc/ansible/collections:/usr/share/ansible/collections', + '[ssh_connection]', + 'ssh_args = -o ProxyCommand=none -C -o ControlMaster=auto -o ControlPersist=60s', + ]) + end + end - include_examples 'a plugin with a settings file', 'ansible' do - let(:expected_config) do - <<~CONFIG - --- - :enabled: https - :ansible_dir: /etc/ansible-test - :working_dir: /tmp/ansible - CONFIG - end - end + describe 'with override parameters' do + let :params do + { + enabled: true, + ansible_dir: '/etc/ansible-test', + working_dir: '/tmp/ansible', + host_key_checking: true, + stdout_callback: 'debug', + manage_runner_repo: false, + } + end - case os - when 'debian-10-x86_64' - it { should_not contain_apt__source('ansible-runner') } - it { should contain_package('python3-ansible-runner').with_ensure('installed') } - when 'redhat-7-x86_64' - it { should_not contain_yumrepo('ansible-runner') } - it { should contain_package('ansible-runner').with_ensure('installed') } - end + it { should contain_class('foreman_proxy::plugin::dynflow') } - it 'should configure ansible.cfg' do - callback = facts[:os]['family'] == 'RedHat' ? 'theforeman.foreman.foreman' : 'foreman' - verify_exact_contents(catalogue, '/etc/foreman-proxy/ansible.cfg', [ - '[defaults]', - "callback_whitelist = #{callback}", - 'local_tmp = /tmp/ansible', - 'host_key_checking = True', - 'stdout_callback = debug', - '[callback_foreman]', - 'url = https://foo.example.com', - 'ssl_key = /etc/puppetlabs/puppet/ssl/private_keys/foo.example.com.pem', - 'ssl_cert = /etc/puppetlabs/puppet/ssl/certs/foo.example.com.pem', - 'verify_certs = /etc/puppetlabs/puppet/ssl/certs/ca.pem', - 'roles_path = /etc/ansible/roles:/usr/share/ansible/roles', - 'collections_paths = /etc/ansible/collections:/usr/share/ansible/collections', - '[ssh_connection]', - 'ssh_args = -o ProxyCommand=none -C -o ControlMaster=auto -o ControlPersist=60s', - ]) - end + include_examples 'a plugin with a settings file', 'ansible' do + let(:expected_config) do + <<~CONFIG + --- + :enabled: https + :ansible_dir: /etc/ansible-test + :working_dir: /tmp/ansible + CONFIG end + end - describe 'with disabled ansible-runner install' do - let :params do - { install_runner: false } - end + case os + when 'debian-10-x86_64' + it { should_not contain_apt__source('ansible-runner') } + it { should contain_package('python3-ansible-runner').with_ensure('installed') } + when 'redhat-7-x86_64' + it { should_not contain_yumrepo('ansible-runner') } + it { should contain_package('ansible-runner').with_ensure('installed') } + end - it 'should not contain ansible-runner' do - should_not contain_class('foreman_proxy::plugin::ansible::runner') - should_not contain_apt__source('ansible-runner') - should_not contain_yumrepo('ansible-runner') - should_not contain_package('ansible-runner') - should_not contain_package('python3-ansible-runner') - end - end + it 'should configure ansible.cfg' do + callback = facts[:os]['family'] == 'RedHat' ? 'theforeman.foreman.foreman' : 'foreman' + verify_exact_contents(catalogue, '/etc/foreman-proxy/ansible.cfg', [ + '[defaults]', + "callback_whitelist = #{callback}", + 'local_tmp = /tmp/ansible', + 'host_key_checking = True', + 'stdout_callback = debug', + '[callback_foreman]', + 'url = https://foo.example.com', + 'ssl_key = /etc/puppetlabs/puppet/ssl/private_keys/foo.example.com.pem', + 'ssl_cert = /etc/puppetlabs/puppet/ssl/certs/foo.example.com.pem', + 'verify_certs = /etc/puppetlabs/puppet/ssl/certs/ca.pem', + 'roles_path = /etc/ansible/roles:/usr/share/ansible/roles', + 'collections_paths = /etc/ansible/collections:/usr/share/ansible/collections', + '[ssh_connection]', + 'ssh_args = -o ProxyCommand=none -C -o ControlMaster=auto -o ControlPersist=60s', + ]) + end + end + + describe 'with disabled ansible-runner install' do + let :params do + { install_runner: false } + end + + it 'should not contain ansible-runner' do + should_not contain_class('foreman_proxy::plugin::ansible::runner') + should_not contain_apt__source('ansible-runner') + should_not contain_yumrepo('ansible-runner') + should_not contain_package('ansible-runner') + should_not contain_package('python3-ansible-runner') end end end diff --git a/spec/classes/plugin/chef_spec.rb b/spec/classes/plugin/chef_spec.rb index db48f686..1372c5d7 100644 --- a/spec/classes/plugin/chef_spec.rb +++ b/spec/classes/plugin/chef_spec.rb @@ -1,56 +1,49 @@ require 'spec_helper' -describe 'foreman_proxy::plugin::chef' do - on_plugin_os.each do |os, os_facts| - context "on #{os}" do - let(:facts) { os_facts } - let(:pre_condition) { 'include foreman_proxy' } - - context 'chef plugin is enabled' do - let :params do - { - :enabled => true - } - end +describe_plugin 'foreman_proxy::plugin::chef' do + context 'chef plugin is enabled' do + let :params do + { + :enabled => true + } + end - include_examples 'a plugin with a settings file', 'chef' do - let(:expected_config) do - <<~CONFIG - --- - :enabled: https - :chef_authenticate_nodes: true - :chef_server_url: https://foo.example.com - # smart-proxy client node needs to have some admin right on chef-server - # in order to retrive all nodes public keys - # e.g. 'host.example.net' - :chef_smartproxy_clientname: foo.example.com - # e.g. /etc/chef/client.pem - :chef_smartproxy_privatekey: /etc/chef/client.pem + include_examples 'a plugin with a settings file', 'chef' do + let(:expected_config) do + <<~CONFIG + --- + :enabled: https + :chef_authenticate_nodes: true + :chef_server_url: https://foo.example.com + # smart-proxy client node needs to have some admin right on chef-server + # in order to retrive all nodes public keys + # e.g. 'host.example.net' + :chef_smartproxy_clientname: foo.example.com + # e.g. /etc/chef/client.pem + :chef_smartproxy_privatekey: /etc/chef/client.pem - # turning of chef_ssl_verify is not recommended as it turn off authentication - # you can try set path to chef server certificate by chef_ssl_pem_file - # before setting chef_ssl_verify to false - # note that chef_ssl_pem_file must contain both private key and certificate - # because chef-api 0.5 requires it - :chef_ssl_verify: true - # :chef_ssl_pem_file: /path - CONFIG - end - end + # turning of chef_ssl_verify is not recommended as it turn off authentication + # you can try set path to chef server certificate by chef_ssl_pem_file + # before setting chef_ssl_verify to false + # note that chef_ssl_pem_file must contain both private key and certificate + # because chef-api 0.5 requires it + :chef_ssl_verify: true + # :chef_ssl_pem_file: /path + CONFIG end + end + end - context 'chef plugin is disabled' do - let :params do - { - :enabled => false - } - end + context 'chef plugin is disabled' do + let :params do + { + :enabled => false + } + end - include_examples 'a plugin with a settings file', 'chef' do - let(:expected_config) { /:enabled: false/ } - let(:expected_enabled) { false } - end - end + include_examples 'a plugin with a settings file', 'chef' do + let(:expected_config) { /:enabled: false/ } + let(:expected_enabled) { false } end end end diff --git a/spec/classes/plugin/container_gateway_spec.rb b/spec/classes/plugin/container_gateway_spec.rb index ad19bd4f..8c3228f1 100644 --- a/spec/classes/plugin/container_gateway_spec.rb +++ b/spec/classes/plugin/container_gateway_spec.rb @@ -1,42 +1,35 @@ require 'spec_helper' -describe 'foreman_proxy::plugin::container_gateway' do - on_plugin_os.each do |os, os_facts| - context "on #{os}" do - let(:facts) { os_facts } - let(:pre_condition) { 'include foreman_proxy' } - - describe 'with default settings' do - include_examples 'a plugin with a settings file', 'container_gateway' do - let(:expected_config) do - <<~CONFIG - --- - # Container Gateway for Katello - :enabled: https - :pulp_endpoint: https://#{facts[:fqdn]} - :sqlite_db_path: /var/lib/foreman-proxy/smart_proxy_container_gateway.db - CONFIG - end - end +describe_plugin 'foreman_proxy::plugin::container_gateway' do + describe 'with default settings' do + include_examples 'a plugin with a settings file', 'container_gateway' do + let(:expected_config) do + <<~CONFIG + --- + # Container Gateway for Katello + :enabled: https + :pulp_endpoint: https://#{facts[:fqdn]} + :sqlite_db_path: /var/lib/foreman-proxy/smart_proxy_container_gateway.db + CONFIG end + end + end - describe 'with overwritten parameters' do - let :params do { - :pulp_endpoint => 'https://test.example.com', - :sqlite_db_path => '/dev/null.db', - } end + describe 'with overwritten parameters' do + let :params do { + :pulp_endpoint => 'https://test.example.com', + :sqlite_db_path => '/dev/null.db', + } end - include_examples 'a plugin with a settings file', 'container_gateway' do - let(:expected_config) do - <<~CONFIG - --- - # Container Gateway for Katello - :enabled: https - :pulp_endpoint: https://test.example.com - :sqlite_db_path: /dev/null.db - CONFIG - end - end + include_examples 'a plugin with a settings file', 'container_gateway' do + let(:expected_config) do + <<~CONFIG + --- + # Container Gateway for Katello + :enabled: https + :pulp_endpoint: https://test.example.com + :sqlite_db_path: /dev/null.db + CONFIG end end end diff --git a/spec/support/plugin.rb b/spec/support/plugin.rb index 25a781cc..0ba3c654 100644 --- a/spec/support/plugin.rb +++ b/spec/support/plugin.rb @@ -13,19 +13,8 @@ def on_plugin_os end def describe_plugin(name, &block) - supported_os = [ - { - 'operatingsystem' => 'RedHat', - 'operatingsystemrelease' => ['7'], - }, - { - 'operatingsystem' => 'Debian', - 'operatingsystemrelease' => ['10'], - }, - ] - describe name do - on_supported_os(supported_os: supported_os).each do |os, os_facts| + on_plugin_os.each do |os, os_facts| context("on #{os}") do let(:facts) { os_facts } let(:pre_condition) { 'include foreman_proxy' }