From a48659ea0d5c8d4f1784cd9adffefe755c4190fa Mon Sep 17 00:00:00 2001 From: Takashi Kajinami Date: Sat, 9 Jul 2022 12:20:10 +0900 Subject: [PATCH] Add acceptance tests for config management resources Change-Id: Ibf9df166c7262d51ed937d4cf4f3fc30099fa57b --- ....rb => 10_basic_ceilometer_config_spec.rb} | 0 spec/acceptance/99_ceilometer_config_spec.rb | 95 +++++++++++++++++++ 2 files changed, 95 insertions(+) rename spec/acceptance/{ceilometer_wsgi_apache_spec.rb => 10_basic_ceilometer_config_spec.rb} (100%) create mode 100644 spec/acceptance/99_ceilometer_config_spec.rb diff --git a/spec/acceptance/ceilometer_wsgi_apache_spec.rb b/spec/acceptance/10_basic_ceilometer_config_spec.rb similarity index 100% rename from spec/acceptance/ceilometer_wsgi_apache_spec.rb rename to spec/acceptance/10_basic_ceilometer_config_spec.rb diff --git a/spec/acceptance/99_ceilometer_config_spec.rb b/spec/acceptance/99_ceilometer_config_spec.rb new file mode 100644 index 00000000..68341576 --- /dev/null +++ b/spec/acceptance/99_ceilometer_config_spec.rb @@ -0,0 +1,95 @@ +require 'spec_helper_acceptance' + +describe 'basic ceilometer_config resource' do + + context 'default parameters' do + + it 'should work with no errors' do + pp= <<-EOS + Exec { logoutput => 'on_failure' } + + File <||> -> Ceilometer_config <||> + File <||> -> Ceilometer_rootwrap_config <||> + + file { '/etc/ceilometer' : + ensure => directory, + } + file { '/etc/ceilometer/ceilometer.conf' : + ensure => file, + } + file { '/etc/ceilometer/rootwrap.conf' : + ensure => file, + } + + ceilometer_config { 'DEFAULT/thisshouldexist' : + value => 'foo', + } + + ceilometer_config { 'DEFAULT/thisshouldnotexist' : + value => '', + } + + ceilometer_config { 'DEFAULT/thisshouldexist2' : + value => '', + ensure_absent_val => 'toto', + } + + ceilometer_config { 'DEFAULT/thisshouldexist3' : + value => ['foo', 'bar'], + } + + ceilometer_config { 'DEFAULT/thisshouldnotexist2' : + value => 'toto', + ensure_absent_val => 'toto', + } + + ceilometer_rootwrap_config { 'DEFAULT/thisshouldexist' : + value => 'foo', + } + + ceilometer_rootwrap_config { 'DEFAULT/thisshouldnotexist' : + value => '', + } + + ceilometer_rootwrap_config { 'DEFAULT/thisshouldexist2' : + value => '', + ensure_absent_val => 'toto', + } + + ceilometer_rootwrap_config { 'DEFAULT/thisshouldnotexist2' : + value => 'toto', + ensure_absent_val => 'toto', + } + EOS + + + # Run it twice and test for idempotency + apply_manifest(pp, :catch_failures => true) + apply_manifest(pp, :catch_changes => true) + end + + describe file('/etc/ceilometer/ceilometer.conf') do + it { is_expected.to exist } + it { is_expected.to contain('thisshouldexist=foo') } + it { is_expected.to contain('thisshouldexist2=') } + it { is_expected.to contain('thisshouldexist3=foo') } + it { is_expected.to contain('thisshouldexist3=bar') } + + describe '#content' do + subject { super().content } + it { is_expected.to_not match /thisshouldnotexist/ } + end + end + + describe file('/etc/ceilometer/rootwrap.conf') do + it { is_expected.to exist } + it { is_expected.to contain('thisshouldexist=foo') } + it { is_expected.to contain('thisshouldexist2=') } + + describe '#content' do + subject { super().content } + it { is_expected.to_not match /thisshouldnotexist/ } + end + end + end +end