diff options
author | Chris Price <chris@puppetlabs.com> | 2013-03-11 13:08:01 -0700 |
---|---|---|
committer | Chris Price <chris@puppetlabs.com> | 2013-03-11 13:08:01 -0700 |
commit | 5fdca54f6e96c861502d6fcff85a563be9d36fa0 (patch) | |
tree | 11e92ce0a2028596b1606a004b55811944a523a7 | |
parent | 2008179ebea70d296f65a1809c961951884a7b11 (diff) | |
parent | 2f22483c87dbaee9b45d121a65f2a09dbe638eaa (diff) | |
download | puppet-inifile-5fdca54f6e96c861502d6fcff85a563be9d36fa0.tar.gz puppet-inifile-5fdca54f6e96c861502d6fcff85a563be9d36fa0.tar.bz2 |
Merge pull request #25 from bodepd/add_purging_support
Add purging support to ini file
-rw-r--r-- | lib/puppet/provider/ini_setting/ruby.rb | 28 | ||||
-rw-r--r-- | lib/puppet/util/ini_file.rb | 8 | ||||
-rw-r--r-- | lib/puppet/util/ini_file/section.rb | 4 | ||||
-rw-r--r-- | spec/unit/puppet/provider/ini_setting/ruby_spec.rb | 78 |
4 files changed, 117 insertions, 1 deletions
diff --git a/lib/puppet/provider/ini_setting/ruby.rb b/lib/puppet/provider/ini_setting/ruby.rb index 2c13847..af7a073 100644 --- a/lib/puppet/provider/ini_setting/ruby.rb +++ b/lib/puppet/provider/ini_setting/ruby.rb @@ -2,6 +2,28 @@ require File.expand_path('../../../util/ini_file', __FILE__) Puppet::Type.type(:ini_setting).provide(:ruby) do + def self.instances + if self.respond_to?(:file_path) + # figure out what to do about the seperator + ini_file = Puppet::Util::IniFile.new(file_path, '=') + resources = [] + ini_file.section_names.each do |section_name| + ini_file.get_settings(section_name).each do |setting, value| + resources.push( + new( + :name => "#{section_name}/#{setting}", + :value => value, + :ensure => :present + ) + ) + end + end + resources + else + raise(Puppet::Error, 'Ini_settings only support collecting instances when a file path is hard coded') + end + end + def exists? ini_file.get_value(section, setting) end @@ -36,7 +58,11 @@ Puppet::Type.type(:ini_setting).provide(:ruby) do end def file_path - resource[:path] + if self.class.respond_to?(:file_path) + self.class.file_path + else + resource[:path] + end end def separator diff --git a/lib/puppet/util/ini_file.rb b/lib/puppet/util/ini_file.rb index 90b0c7b..48600ea 100644 --- a/lib/puppet/util/ini_file.rb +++ b/lib/puppet/util/ini_file.rb @@ -23,6 +23,14 @@ module Util @section_names end + def get_settings(section_name) + section = @sections_hash[section_name] + section.setting_names.inject({}) do |result, setting| + result[setting] = section.get_value(setting) + result + end + end + def get_value(section_name, setting) if (@sections_hash.has_key?(section_name)) @sections_hash[section_name].get_value(setting) diff --git a/lib/puppet/util/ini_file/section.rb b/lib/puppet/util/ini_file/section.rb index ba1a783..9682d7f 100644 --- a/lib/puppet/util/ini_file/section.rb +++ b/lib/puppet/util/ini_file/section.rb @@ -32,6 +32,10 @@ class IniFile @end_line.nil? end + def setting_names + @existing_settings.keys | @additional_settings.keys + end + def get_value(setting_name) @existing_settings[setting_name] || @additional_settings[setting_name] end diff --git a/spec/unit/puppet/provider/ini_setting/ruby_spec.rb b/spec/unit/puppet/provider/ini_setting/ruby_spec.rb index 4f8bdc1..7204f88 100644 --- a/spec/unit/puppet/provider/ini_setting/ruby_spec.rb +++ b/spec/unit/puppet/provider/ini_setting/ruby_spec.rb @@ -28,6 +28,84 @@ describe provider_class do end end + context 'when calling instances' do + + let :orig_content do + '' + end + + it 'should fail when file path is not set' do + expect { + described_class.instances + }.to raise_error(Puppet::Error, 'Ini_settings only support collecting instances when a file path is hard coded') + end + + context 'when file path is set' do + it 'should return [] when file is empty' do + provider_class.stubs(:file_path).returns(emptyfile) + provider_class.instances.should == [] + end + it 'should override the provider instances file_path' do + provider_class.stubs(:file_path).returns('/some/file/path') + resource = Puppet::Type::Ini_setting.new(common_params) + provider = provider_class.new(resource) + provider.file_path.should == '/some/file/path' + end + context 'when file has contecnts' do + let(:orig_content) { + <<-EOS +# This is a comment +[section1] +; This is also a comment +foo=foovalue + +bar = barvalue +master = true +[section2] + +foo= foovalue2 +baz=bazvalue +url = http://192.168.1.1:8080 +[section:sub] +subby=bar + #another comment + ; yet another comment + EOS + } + + it 'should be able to parse the results' do + provider_class.stubs(:file_path).returns(tmpfile) + provider_class.instances.size == 7 + expected_array = [ + {:name => 'section1/foo', :value => 'foovalue' }, + {:name => 'section1/bar', :value => 'barvalue' }, + {:name => 'section1/master', :value => 'true' }, + {:name => 'section2/foo', :value => 'foovalue2' }, + {:name => 'section2/baz', :value => 'bazvalue' }, + {:name => 'section2/url', :value => 'http://192.168.1.1:8080' }, + {:name => 'section:sub/subby', :value => 'bar' } + ] + real_array = [] + ensure_array = [] + provider_class.instances.each do |x| + prop_hash = x.instance_variable_get(:@property_hash) + ensure_value = prop_hash.delete(:ensure) + ensure_array.push(ensure_value) + real_array.push(prop_hash) + end + puts ensure_array.inspect + puts real_array.inspect + ensure_array.uniq.should == [:present] + ((real_array - expected_array) && (expected_array - real_array)).should == [] + + end + + end + + end + + end + context "when ensuring that a setting is present" do let(:orig_content) { <<-EOS |