Added ability to specify section_prefix and section_suffix to accomodate files with sections that don't follow [section_name] format. AIX for example uses section_name: format.
This commit is contained in:
parent
5d70bafff5
commit
b0fb47d4ec
5 changed files with 375 additions and 5 deletions
|
@ -65,6 +65,24 @@ ini_subsetting {'sample subsetting':
|
||||||
}
|
}
|
||||||
~~~
|
~~~
|
||||||
|
|
||||||
|
###Use a non-standard section header
|
||||||
|
|
||||||
|
~~~
|
||||||
|
default:
|
||||||
|
minage = 1
|
||||||
|
maxage = 13
|
||||||
|
|
||||||
|
ini_setting { 'default minage':
|
||||||
|
ensure => present,
|
||||||
|
path => '/etc/security/users',
|
||||||
|
section => 'default',
|
||||||
|
setting => 'minage',
|
||||||
|
value => '1',
|
||||||
|
section_prefix => '',
|
||||||
|
section_suffix => ':',
|
||||||
|
}
|
||||||
|
~~~
|
||||||
|
|
||||||
###Implement child providers
|
###Implement child providers
|
||||||
|
|
||||||
|
|
||||||
|
@ -176,6 +194,16 @@ Determines whether the specified setting should exist. Valid options: 'present'
|
||||||
|
|
||||||
*Optional.* Supplies a value for the specified setting. Valid options: a string. Default value: undefined.
|
*Optional.* Supplies a value for the specified setting. Valid options: a string. Default value: undefined.
|
||||||
|
|
||||||
|
##### `section_prefix`
|
||||||
|
|
||||||
|
*Optional.* Designates the string that will appear before the section's name. Default value: "["
|
||||||
|
|
||||||
|
##### `section_suffix`
|
||||||
|
|
||||||
|
*Optional.* Designates the string that will appear after the section's name. Default value: "]"
|
||||||
|
|
||||||
|
**NOTE:** The way this type finds all sections in the file is by looking for lines like `${section_prefix}${title}${section_suffix}`
|
||||||
|
|
||||||
### Type: ini_subsetting
|
### Type: ini_subsetting
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -94,9 +94,25 @@ Puppet::Type.type(:ini_setting).provide(:ruby) do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def section_prefix
|
||||||
|
if resource.class.validattr?(:section_prefix)
|
||||||
|
resource[:section_prefix] || '['
|
||||||
|
else
|
||||||
|
'['
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def section_suffix
|
||||||
|
if resource.class.validattr?(:section_suffix)
|
||||||
|
resource[:section_suffix] || ']'
|
||||||
|
else
|
||||||
|
']'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
def ini_file
|
def ini_file
|
||||||
@ini_file ||= Puppet::Util::IniFile.new(file_path, separator)
|
@ini_file ||= Puppet::Util::IniFile.new(file_path, separator, section_prefix, section_suffix)
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -39,5 +39,16 @@ Puppet::Type.newtype(:ini_setting) do
|
||||||
desc 'The value of the setting to be defined.'
|
desc 'The value of the setting to be defined.'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
newparam(:section_prefix) do
|
||||||
|
desc 'The prefix to the section name\'s header.' +
|
||||||
|
'Defaults to \'[\'.'
|
||||||
|
defaultto('[')
|
||||||
|
end
|
||||||
|
|
||||||
|
newparam(:section_suffix) do
|
||||||
|
desc 'The suffix to the section name\'s header.' +
|
||||||
|
'Defaults to \']\'.'
|
||||||
|
defaultto(']')
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -5,11 +5,14 @@ module Puppet
|
||||||
module Util
|
module Util
|
||||||
class IniFile
|
class IniFile
|
||||||
|
|
||||||
def initialize(path, key_val_separator = ' = ')
|
def initialize(path, key_val_separator = ' = ', section_prefix = '[', section_suffix = ']')
|
||||||
|
|
||||||
k_v_s = key_val_separator.strip
|
k_v_s = key_val_separator.strip
|
||||||
|
|
||||||
@@SECTION_REGEX = /^\s*\[([^\]]*)\]\s*$/
|
@section_prefix = section_prefix
|
||||||
|
@section_suffix = section_suffix
|
||||||
|
|
||||||
|
@@SECTION_REGEX = section_regex
|
||||||
@@SETTING_REGEX = /^(\s*)([^#;\s]|[^#;\s].*?[^\s#{k_v_s}])(\s*#{k_v_s}\s*)(.*)\s*$/
|
@@SETTING_REGEX = /^(\s*)([^#;\s]|[^#;\s].*?[^\s#{k_v_s}])(\s*#{k_v_s}\s*)(.*)\s*$/
|
||||||
@@COMMENTED_SETTING_REGEX = /^(\s*)[#;]+(\s*)(.*?[^\s#{k_v_s}])(\s*#{k_v_s}[ \t]*)(.*)\s*$/
|
@@COMMENTED_SETTING_REGEX = /^(\s*)[#;]+(\s*)(.*?[^\s#{k_v_s}])(\s*#{k_v_s}[ \t]*)(.*)\s*$/
|
||||||
|
|
||||||
|
@ -22,6 +25,26 @@ module Util
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def section_regex
|
||||||
|
# Only put in prefix/suffix if they exist
|
||||||
|
# Also, if the prefix is '', the negated
|
||||||
|
# set match should be a match all instead.
|
||||||
|
r_string = '^\s*'
|
||||||
|
r_string += Regexp.escape(@section_prefix)
|
||||||
|
r_string += '('
|
||||||
|
if @section_prefix != ''
|
||||||
|
r_string += '[^'
|
||||||
|
r_string += Regexp.escape(@section_prefix)
|
||||||
|
r_string += ']'
|
||||||
|
else
|
||||||
|
r_string += '.'
|
||||||
|
end
|
||||||
|
r_string += '*)'
|
||||||
|
r_string += Regexp.escape(@section_suffix)
|
||||||
|
r_string += '\s*$'
|
||||||
|
/#{r_string}/
|
||||||
|
end
|
||||||
|
|
||||||
def section_names
|
def section_names
|
||||||
@section_names
|
@section_names
|
||||||
end
|
end
|
||||||
|
@ -107,7 +130,7 @@ module Util
|
||||||
whitespace_buffer = []
|
whitespace_buffer = []
|
||||||
|
|
||||||
if (section.is_new_section?) && (! section.is_global?)
|
if (section.is_new_section?) && (! section.is_global?)
|
||||||
fh.puts("\n[#{section.name}]")
|
fh.puts("\n#{@section_prefix}#{section.name}#{@section_suffix}")
|
||||||
end
|
end
|
||||||
|
|
||||||
if ! section.is_new_section?
|
if ! section.is_new_section?
|
||||||
|
|
|
@ -137,6 +137,9 @@ url = http://192.168.1.1:8080
|
||||||
subby=bar
|
subby=bar
|
||||||
#another comment
|
#another comment
|
||||||
; yet another comment
|
; yet another comment
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
EOS
|
EOS
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -164,6 +167,42 @@ yahoo = yippee
|
||||||
subby=bar
|
subby=bar
|
||||||
#another comment
|
#another comment
|
||||||
; yet another comment
|
; yet another comment
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
|
EOS
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "should add a missing setting to the correct section with pre/suffix" do
|
||||||
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
|
:section => 'nonstandard',
|
||||||
|
:setting => 'yahoo', :value => 'yippee',
|
||||||
|
:section_prefix => '-', :section_suffix => '-'))
|
||||||
|
provider = described_class.new(resource)
|
||||||
|
provider.exists?.should be false
|
||||||
|
provider.create
|
||||||
|
validate_file(<<-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
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
|
yahoo = yippee
|
||||||
EOS
|
EOS
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
@ -191,6 +230,9 @@ url = http://192.168.1.1:8080
|
||||||
subby=bar
|
subby=bar
|
||||||
#another comment
|
#another comment
|
||||||
; yet another comment
|
; yet another comment
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
yahoo = yippee
|
yahoo = yippee
|
||||||
EOS
|
EOS
|
||||||
)
|
)
|
||||||
|
@ -219,6 +261,41 @@ url = http://192.168.1.1:8080
|
||||||
subby=bar
|
subby=bar
|
||||||
#another comment
|
#another comment
|
||||||
; yet another comment
|
; yet another comment
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
|
EOS
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "should modify an existing setting with pre/suffix with a different value" do
|
||||||
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
|
:section => 'nonstandard',
|
||||||
|
:setting => 'shoes', :value => 'orange',
|
||||||
|
:section_prefix => '-', :section_suffix => '-' ))
|
||||||
|
provider = described_class.new(resource)
|
||||||
|
provider.exists?.should be true
|
||||||
|
provider.value=('orange')
|
||||||
|
validate_file(<<-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
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = orange
|
||||||
EOS
|
EOS
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
@ -247,6 +324,9 @@ url = http://192.168.1.1:8080
|
||||||
subby=foo
|
subby=foo
|
||||||
#another comment
|
#another comment
|
||||||
; yet another comment
|
; yet another comment
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
EOS
|
EOS
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
@ -276,6 +356,43 @@ url = http://192.168.0.1:8080
|
||||||
subby=bar
|
subby=bar
|
||||||
#another comment
|
#another comment
|
||||||
; yet another comment
|
; yet another comment
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
|
EOS
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "should be able to handle settings with pre/suffix with non alphanumbering settings " do
|
||||||
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
|
:section => 'nonstandard',
|
||||||
|
:setting => 'shoes', :value => 'http://192.168.0.1:8080',
|
||||||
|
:section_prefix => '-', :section_suffix => '-' ))
|
||||||
|
provider = described_class.new(resource)
|
||||||
|
provider.exists?.should be true
|
||||||
|
provider.value.should == 'purple'
|
||||||
|
provider.value=('http://192.168.0.1:8080')
|
||||||
|
|
||||||
|
validate_file( <<-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
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = http://192.168.0.1:8080
|
||||||
EOS
|
EOS
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
@ -287,6 +404,15 @@ subby=bar
|
||||||
provider.exists?.should be true
|
provider.exists?.should be true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "should recognize an existing setting with pre/suffix with the specified value" do
|
||||||
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
|
:section => 'nonstandard',
|
||||||
|
:setting => 'shoes', :value => 'purple',
|
||||||
|
:section_prefix => '-', :section_suffix => '-' ))
|
||||||
|
provider = described_class.new(resource)
|
||||||
|
provider.exists?.should be true
|
||||||
|
end
|
||||||
|
|
||||||
it "should add a new section if the section does not exist" do
|
it "should add a new section if the section does not exist" do
|
||||||
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
:section => "section3", :setting => 'huzzah', :value => 'shazaam'))
|
:section => "section3", :setting => 'huzzah', :value => 'shazaam'))
|
||||||
|
@ -311,12 +437,49 @@ subby=bar
|
||||||
#another comment
|
#another comment
|
||||||
; yet another comment
|
; yet another comment
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
|
|
||||||
[section3]
|
[section3]
|
||||||
huzzah = shazaam
|
huzzah = shazaam
|
||||||
EOS
|
EOS
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "should add a new section with pre/suffix if the section does not exist" do
|
||||||
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
|
:section => "section3", :setting => 'huzzah', :value => 'shazaam',
|
||||||
|
:section_prefix => '-', :section_suffix => '-' ))
|
||||||
|
provider = described_class.new(resource)
|
||||||
|
provider.exists?.should be false
|
||||||
|
provider.create
|
||||||
|
validate_file(<<-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
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
|
|
||||||
|
-section3-
|
||||||
|
huzzah = shazaam
|
||||||
|
EOS
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
it "should add a new section if the section does not exist - with colon" do
|
it "should add a new section if the section does not exist - with colon" do
|
||||||
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
:section => "section:subsection", :setting => 'huzzah', :value => 'shazaam'))
|
:section => "section:subsection", :setting => 'huzzah', :value => 'shazaam'))
|
||||||
|
@ -341,12 +504,49 @@ subby=bar
|
||||||
#another comment
|
#another comment
|
||||||
; yet another comment
|
; yet another comment
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
|
|
||||||
[section:subsection]
|
[section:subsection]
|
||||||
huzzah = shazaam
|
huzzah = shazaam
|
||||||
EOS
|
EOS
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "should add a new section with pre/suffix if the section does not exist - with colon" do
|
||||||
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
|
:section => "section:subsection", :setting => 'huzzah', :value => 'shazaam',
|
||||||
|
:section_prefix => '-', :section_suffix => '-' ))
|
||||||
|
provider = described_class.new(resource)
|
||||||
|
provider.exists?.should be false
|
||||||
|
provider.create
|
||||||
|
validate_file(<<-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
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
|
|
||||||
|
-section:subsection-
|
||||||
|
huzzah = shazaam
|
||||||
|
EOS
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
it "should add a new section if no sections exists" do
|
it "should add a new section if no sections exists" do
|
||||||
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
:section => "section1", :setting => 'setting1', :value => 'hellowworld', :path => emptyfile))
|
:section => "section1", :setting => 'setting1', :value => 'hellowworld', :path => emptyfile))
|
||||||
|
@ -359,6 +559,19 @@ setting1 = hellowworld
|
||||||
", emptyfile)
|
", emptyfile)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "should add a new section with pre/suffix if no sections exists" do
|
||||||
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
|
:section => "section1", :setting => 'setting1', :value => 'hellowworld', :path => emptyfile,
|
||||||
|
:section_prefix => '-', :section_suffix => '-' ))
|
||||||
|
provider = described_class.new(resource)
|
||||||
|
provider.exists?.should be false
|
||||||
|
provider.create
|
||||||
|
validate_file("
|
||||||
|
-section1-
|
||||||
|
setting1 = hellowworld
|
||||||
|
", emptyfile)
|
||||||
|
end
|
||||||
|
|
||||||
it "should add a new section with colon if no sections exists" do
|
it "should add a new section with colon if no sections exists" do
|
||||||
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
:section => "section:subsection", :setting => 'setting1', :value => 'hellowworld', :path => emptyfile))
|
:section => "section:subsection", :setting => 'setting1', :value => 'hellowworld', :path => emptyfile))
|
||||||
|
@ -371,6 +584,18 @@ setting1 = hellowworld
|
||||||
", emptyfile)
|
", emptyfile)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "should add a new section with pre/suffix with colon if no sections exists" do
|
||||||
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
|
:section => "section:subsection", :setting => 'setting1', :value => 'hellowworld', :path => emptyfile,
|
||||||
|
:section_prefix => '-', :section_suffix => '-' ))
|
||||||
|
provider = described_class.new(resource)
|
||||||
|
provider.exists?.should be false
|
||||||
|
provider.create
|
||||||
|
validate_file("
|
||||||
|
-section:subsection-
|
||||||
|
setting1 = hellowworld
|
||||||
|
", emptyfile)
|
||||||
|
end
|
||||||
it "should be able to handle variables of any type" do
|
it "should be able to handle variables of any type" do
|
||||||
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
:section => "section1", :setting => 'master', :value => true))
|
:section => "section1", :setting => 'master', :value => true))
|
||||||
|
@ -576,6 +801,9 @@ url = http://192.168.1.1:8080
|
||||||
subby=bar
|
subby=bar
|
||||||
#another comment
|
#another comment
|
||||||
; yet another comment
|
; yet another comment
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
EOS
|
EOS
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -600,6 +828,38 @@ url = http://192.168.1.1:8080
|
||||||
subby=bar
|
subby=bar
|
||||||
#another comment
|
#another comment
|
||||||
; yet another comment
|
; yet another comment
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
|
EOS
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "should remove a setting with pre/suffix that exists" do
|
||||||
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
|
:section => 'nonstandard', :setting => 'shoes', :ensure => 'absent',
|
||||||
|
:section_prefix => '-', :section_suffix => '-' ))
|
||||||
|
provider = described_class.new(resource)
|
||||||
|
provider.exists?.should be true
|
||||||
|
provider.destroy
|
||||||
|
validate_file(<<-EOS
|
||||||
|
[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
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
EOS
|
EOS
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
@ -626,12 +886,44 @@ url = http://192.168.1.1:8080
|
||||||
subby=bar
|
subby=bar
|
||||||
#another comment
|
#another comment
|
||||||
; yet another comment
|
; yet another comment
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
|
EOS
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "should do nothing for a setting with pre/suffix that does not exist" do
|
||||||
|
resource = Puppet::Type::Ini_setting.new(common_params.merge(
|
||||||
|
:section => 'nonstandard', :setting => 'foo', :ensure => 'absent',
|
||||||
|
:section_prefix => '-', :section_suffix => '-' ))
|
||||||
|
provider = described_class.new(resource)
|
||||||
|
provider.exists?.should be false
|
||||||
|
provider.destroy
|
||||||
|
validate_file(<<-EOS
|
||||||
|
[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
|
||||||
|
|
||||||
|
-nonstandard-
|
||||||
|
shoes = purple
|
||||||
EOS
|
EOS
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
context "when dealing with indentation in sections" do
|
context "when dealing with indentation in sections" do
|
||||||
let(:orig_content) {
|
let(:orig_content) {
|
||||||
<<-EOS
|
<<-EOS
|
||||||
|
|
Loading…
Reference in a new issue