Convert to using .tmpdir instead of a hardcoded /tmp, so this works

on Windows too.
This commit is contained in:
Ashley Penney 2014-02-27 22:57:12 +00:00
parent ca7e441e9f
commit 2aceaef207
2 changed files with 42 additions and 38 deletions

View file

@ -1,8 +1,10 @@
require 'spec_helper_acceptance' require 'spec_helper_acceptance'
tmpdir = default.tmpdir('tmp')
describe 'ini_setting resource' do describe 'ini_setting resource' do
after :all do after :all do
shell("rm /tmp/*.ini", :acceptable_exit_codes => [0,1,2]) shell("rm #{tmpdir}/*.ini", :acceptable_exit_codes => [0,1,2])
end end
shared_examples 'has_content' do |path,pp,content| shared_examples 'has_content' do |path,pp,content|
@ -51,14 +53,14 @@ describe 'ini_setting resource' do
pp = <<-EOS pp = <<-EOS
ini_setting { 'ensure => present for section': ini_setting { 'ensure => present for section':
ensure => present, ensure => present,
path => '/tmp/ini_setting.ini', path => "#{tmpdir}/ini_setting.ini",
section => 'one', section => 'one',
setting => 'two', setting => 'two',
value => 'three', value => 'three',
} }
ini_setting { 'ensure => present for global': ini_setting { 'ensure => present for global':
ensure => present, ensure => present,
path => '/tmp/ini_setting.ini', path => "#{tmpdir}/ini_setting.ini",
section => '', section => '',
setting => 'four', setting => 'four',
value => 'five', value => 'five',
@ -70,7 +72,7 @@ describe 'ini_setting resource' do
expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("") expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("")
end end
describe file('/tmp/ini_setting.ini') do describe file("#{tmpdir}/ini_setting.ini") do
it { should be_file } it { should be_file }
#XXX Solaris 10 doesn't support multi-line grep #XXX Solaris 10 doesn't support multi-line grep
it("should contain four = five\n[one]\ntwo = three", :unless => fact('osfamily') == 'Solaris') { it("should contain four = five\n[one]\ntwo = three", :unless => fact('osfamily') == 'Solaris') {
@ -81,13 +83,13 @@ describe 'ini_setting resource' do
context '=> absent for key/value' do context '=> absent for key/value' do
before :all do before :all do
shell('echo -e "four = five\n[one]\ntwo = three" > /tmp/ini_setting.ini') shell("echo -e \"four = five\n[one]\ntwo = three\" > #{tmpdir}/ini_setting.ini")
end end
pp = <<-EOS pp = <<-EOS
ini_setting { 'ensure => absent for key/value': ini_setting { 'ensure => absent for key/value':
ensure => absent, ensure => absent,
path => '/tmp/ini_setting.ini', path => "#{tmpdir}/ini_setting.ini",
section => 'one', section => 'one',
setting => 'two', setting => 'two',
value => 'three', value => 'three',
@ -99,7 +101,7 @@ describe 'ini_setting resource' do
expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("") expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("")
end end
describe file('/tmp/ini_setting.ini') do describe file("#{tmpdir}/ini_setting.ini") do
it { should be_file } it { should be_file }
it { should contain('four = five') } it { should contain('four = five') }
it { should contain('[one]') } it { should contain('[one]') }
@ -109,17 +111,17 @@ describe 'ini_setting resource' do
context '=> absent for section', :pending => "cannot ensure absent on a section" do context '=> absent for section', :pending => "cannot ensure absent on a section" do
before :all do before :all do
shell('echo -e "four = five\n[one]\ntwo = three" > /tmp/ini_setting.ini') shell("echo -e \"four = five\n[one]\ntwo = three\" > #{tmpdir}/ini_setting.ini")
end end
after :all do after :all do
shell("cat /tmp/ini_setting.ini", :acceptable_exit_codes => [0,1,2]) shell("cat #{tmpdir}/ini_setting.ini", :acceptable_exit_codes => [0,1,2])
shell("rm /tmp/ini_setting.ini", :acceptable_exit_codes => [0,1,2]) shell("rm #{tmpdir}/ini_setting.ini", :acceptable_exit_codes => [0,1,2])
end end
pp = <<-EOS pp = <<-EOS
ini_setting { 'ensure => absent for section': ini_setting { 'ensure => absent for section':
ensure => absent, ensure => absent,
path => '/tmp/ini_setting.ini', path => "#{tmpdir}/ini_setting.ini",
section => 'one', section => 'one',
} }
EOS EOS
@ -129,7 +131,7 @@ describe 'ini_setting resource' do
expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("") expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("")
end end
describe file('/tmp/ini_setting.ini') do describe file("#{tmpdir}/ini_setting.ini") do
it { should be_file } it { should be_file }
it { should contain('four = five') } it { should contain('four = five') }
it { should_not contain('[one]') } it { should_not contain('[one]') }
@ -139,17 +141,17 @@ describe 'ini_setting resource' do
context '=> absent for global' do context '=> absent for global' do
before :all do before :all do
shell('echo -e "four = five\n[one]\ntwo = three" > /tmp/ini_setting.ini') shell("echo -e \"four = five\n[one]\ntwo = three\" > #{tmpdir}/ini_setting.ini")
end end
after :all do after :all do
shell("cat /tmp/ini_setting.ini", :acceptable_exit_codes => [0,1,2]) shell("cat #{tmpdir}/ini_setting.ini", :acceptable_exit_codes => [0,1,2])
shell("rm /tmp/ini_setting.ini", :acceptable_exit_codes => [0,1,2]) shell("rm #{tmpdir}/ini_setting.ini", :acceptable_exit_codes => [0,1,2])
end end
pp = <<-EOS pp = <<-EOS
ini_setting { 'ensure => absent for global': ini_setting { 'ensure => absent for global':
ensure => absent, ensure => absent,
path => '/tmp/ini_setting.ini', path => "#{tmpdir}/ini_setting.ini",
section => '', section => '',
setting => 'four', setting => 'four',
value => 'five', value => 'five',
@ -161,7 +163,7 @@ describe 'ini_setting resource' do
expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("") expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("")
end end
describe file('/tmp/ini_setting.ini') do describe file("#{tmpdir}/ini_setting.ini") do
it { should be_file } it { should be_file }
it { should_not contain('four = five') } it { should_not contain('four = five') }
it { should contain('[one]') } it { should contain('[one]') }
@ -180,12 +182,12 @@ describe 'ini_setting resource' do
pp = <<-EOS pp = <<-EOS
ini_setting { "#{parameter_list}": ini_setting { "#{parameter_list}":
ensure => present, ensure => present,
path => '/tmp/ini_setting.ini', path => "#{tmpdir}/ini_setting.ini",
#{parameter_list} #{parameter_list}
} }
EOS EOS
it_behaves_like 'has_content', '/tmp/ini_setting.ini', pp, content it_behaves_like 'has_content', "#{tmpdir}/ini_setting.ini", pp, content
end end
end end
@ -201,21 +203,21 @@ describe 'ini_setting resource' do
pp = <<-EOS pp = <<-EOS
ini_setting { "#{parameter_list}": ini_setting { "#{parameter_list}":
ensure => present, ensure => present,
path => '/tmp/ini_setting.ini', path => "#{tmpdir}/ini_setting.ini",
#{parameter_list} #{parameter_list}
} }
EOS EOS
it_behaves_like 'has_error', '/tmp/ini_setting.ini', pp, error it_behaves_like 'has_error', "#{tmpdir}/ini_setting.ini", pp, error
end end
end end
end end
describe 'path parameter' do describe 'path parameter' do
[ [
"/tmp/one.ini", "#{tmpdir}/one.ini",
"/tmp/two.ini", "#{tmpdir}/two.ini",
"/tmp/three.ini", "#{tmpdir}/three.ini",
].each do |path| ].each do |path|
context "path => #{path}" do context "path => #{path}" do
pp = <<-EOS pp = <<-EOS
@ -260,12 +262,12 @@ describe 'ini_setting resource' do
section => 'one', section => 'one',
setting => 'two', setting => 'two',
value => 'three', value => 'three',
path => '/tmp/key_val_separator.ini', path => "#{tmpdir}/key_val_separator.ini",
#{parameter} #{parameter}
} }
EOS EOS
it_behaves_like 'has_content', '/tmp/key_val_separator.ini', pp, content it_behaves_like 'has_content', "#{tmpdir}/key_val_separator.ini", pp, content
end end
end end
@ -282,12 +284,12 @@ describe 'ini_setting resource' do
section => 'one', section => 'one',
setting => 'two', setting => 'two',
value => 'three', value => 'three',
path => '/tmp/key_val_separator.ini', path => "#{tmpdir}/key_val_separator.ini",
#{parameter} #{parameter}
} }
EOS EOS
it_behaves_like 'has_error', '/tmp/key_val_separator.ini', pp, error it_behaves_like 'has_error', "#{tmpdir}/key_val_separator.ini", pp, error
end end
end end
end end

View file

@ -1,8 +1,10 @@
require 'spec_helper_acceptance' require 'spec_helper_acceptance'
tmpdir = default.tmpdir('tmp')
describe 'ini_subsetting resource' do describe 'ini_subsetting resource' do
after :all do after :all do
shell("rm /tmp/*.ini", :acceptable_exit_codes => [0,1,2]) shell("rm #{tmpdir}/*.ini", :acceptable_exit_codes => [0,1,2])
end end
shared_examples 'has_content' do |path,pp,content| shared_examples 'has_content' do |path,pp,content|
@ -48,7 +50,7 @@ describe 'ini_subsetting resource' do
pp = <<-EOS pp = <<-EOS
ini_subsetting { 'ensure => present for alpha': ini_subsetting { 'ensure => present for alpha':
ensure => present, ensure => present,
path => '/tmp/ini_subsetting.ini', path => "#{tmpdir}/ini_subsetting.ini",
section => 'one', section => 'one',
setting => 'key', setting => 'key',
subsetting => 'alpha', subsetting => 'alpha',
@ -56,7 +58,7 @@ describe 'ini_subsetting resource' do
} }
ini_subsetting { 'ensure => present for beta': ini_subsetting { 'ensure => present for beta':
ensure => present, ensure => present,
path => '/tmp/ini_subsetting.ini', path => "#{tmpdir}/ini_subsetting.ini",
section => 'one', section => 'one',
setting => 'key', setting => 'key',
subsetting => 'beta', subsetting => 'beta',
@ -69,7 +71,7 @@ describe 'ini_subsetting resource' do
expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("") expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("")
end end
describe file('/tmp/ini_subsetting.ini') do describe file("#{tmpdir}/ini_subsetting.ini") do
it { should be_file } it { should be_file }
#XXX Solaris 10 doesn't support multi-line grep #XXX Solaris 10 doesn't support multi-line grep
it("should contain [one]\nkey = alphabet betatrons", :unless => fact('osfamily') == 'Solaris') { it("should contain [one]\nkey = alphabet betatrons", :unless => fact('osfamily') == 'Solaris') {
@ -80,13 +82,13 @@ describe 'ini_subsetting resource' do
context 'ensure => absent' do context 'ensure => absent' do
before :all do before :all do
shell('echo -e "[one]\nkey = alphabet betatrons" > /tmp/ini_subsetting.ini') shell("echo -e \"[one]\nkey = alphabet betatrons\" > #{tmpdir}/ini_subsetting.ini")
end end
pp = <<-EOS pp = <<-EOS
ini_subsetting { 'ensure => absent for subsetting': ini_subsetting { 'ensure => absent for subsetting':
ensure => absent, ensure => absent,
path => '/tmp/ini_subsetting.ini', path => "#{tmpdir}/ini_subsetting.ini",
section => 'one', section => 'one',
setting => 'key', setting => 'key',
subsetting => 'alpha', subsetting => 'alpha',
@ -98,7 +100,7 @@ describe 'ini_subsetting resource' do
expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("") expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("")
end end
describe file('/tmp/ini_subsetting.ini') do describe file("#{tmpdir}/ini_subsetting.ini") do
it { should be_file } it { should be_file }
it { should contain('[one]') } it { should contain('[one]') }
it { should contain('key = betatrons') } it { should contain('key = betatrons') }
@ -125,7 +127,7 @@ describe 'ini_subsetting resource' do
setting => 'two', setting => 'two',
subsetting => 'twine', subsetting => 'twine',
value => 'three', value => 'three',
path => '/tmp/subsetting_separator.ini', path => "#{tmpdir}/subsetting_separator.ini",
#{parameter} #{parameter}
} }
ini_subsetting { "foobar": ini_subsetting { "foobar":
@ -134,12 +136,12 @@ describe 'ini_subsetting resource' do
setting => 'two', setting => 'two',
subsetting => 'foo', subsetting => 'foo',
value => 'bar', value => 'bar',
path => '/tmp/subsetting_separator.ini', path => "#{tmpdir}/subsetting_separator.ini",
#{parameter} #{parameter}
} }
EOS EOS
it_behaves_like 'has_content', '/tmp/subsetting_separator.ini', pp, content it_behaves_like 'has_content', "#{tmpdir}/subsetting_separator.ini", pp, content
end end
end end
end end