241 lines
6.7 KiB
Ruby
241 lines
6.7 KiB
Ruby
require 'spec_helper_acceptance'
|
|
|
|
describe 'replacement of' do
|
|
context 'file' do
|
|
context 'should not succeed' do
|
|
before(:all) do
|
|
shell('mkdir -p /tmp/concat')
|
|
shell('echo "file exists" > /tmp/concat/file')
|
|
end
|
|
after(:all) do
|
|
shell('rm -rf /tmp/concat /var/lib/puppet/concat')
|
|
end
|
|
|
|
pp = <<-EOS
|
|
concat { '/tmp/concat/file':
|
|
replace => false,
|
|
}
|
|
|
|
concat::fragment { '1':
|
|
target => '/tmp/concat/file',
|
|
content => '1',
|
|
}
|
|
|
|
concat::fragment { '2':
|
|
target => '/tmp/concat/file',
|
|
content => '2',
|
|
}
|
|
EOS
|
|
|
|
it 'applies the manifest twice with no stderr' do
|
|
expect(apply_manifest(pp, :catch_failures => true).stderr).to eq("")
|
|
expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("")
|
|
end
|
|
|
|
describe file('/tmp/concat/file') do
|
|
it { should be_file }
|
|
it { should contain 'file exists' }
|
|
it { should_not contain '1' }
|
|
it { should_not contain '2' }
|
|
end
|
|
end
|
|
|
|
context 'should succeed' do
|
|
before(:all) do
|
|
shell('mkdir -p /tmp/concat')
|
|
shell('echo "file exists" > /tmp/concat/file')
|
|
end
|
|
after(:all) do
|
|
shell('rm -rf /tmp/concat /var/lib/puppet/concat')
|
|
end
|
|
|
|
pp = <<-EOS
|
|
concat { '/tmp/concat/file':
|
|
replace => true,
|
|
}
|
|
|
|
concat::fragment { '1':
|
|
target => '/tmp/concat/file',
|
|
content => '1',
|
|
}
|
|
|
|
concat::fragment { '2':
|
|
target => '/tmp/concat/file',
|
|
content => '2',
|
|
}
|
|
EOS
|
|
|
|
it 'applies the manifest twice with no stderr' do
|
|
expect(apply_manifest(pp, :catch_failures => true).stderr).to eq("")
|
|
expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("")
|
|
end
|
|
|
|
describe file('/tmp/concat/file') do
|
|
it { should be_file }
|
|
it { should_not contain 'file exists' }
|
|
it { should contain '1' }
|
|
it { should contain '2' }
|
|
end
|
|
end
|
|
end # file
|
|
|
|
context 'symlink' do
|
|
context 'should not succeed' do
|
|
# XXX the core puppet file type will replace a symlink with a plain file
|
|
# when using ensure => present and source => ... but it will not when using
|
|
# ensure => present and content => ...; this is somewhat confusing behavior
|
|
before(:all) do
|
|
shell('mkdir -p /tmp/concat')
|
|
shell('ln -s /tmp/concat/dangling /tmp/concat/file')
|
|
end
|
|
after(:all) do
|
|
shell('rm -rf /tmp/concat /var/lib/puppet/concat')
|
|
end
|
|
|
|
pp = <<-EOS
|
|
concat { '/tmp/concat/file':
|
|
replace => false,
|
|
}
|
|
|
|
concat::fragment { '1':
|
|
target => '/tmp/concat/file',
|
|
content => '1',
|
|
}
|
|
|
|
concat::fragment { '2':
|
|
target => '/tmp/concat/file',
|
|
content => '2',
|
|
}
|
|
EOS
|
|
|
|
it 'applies the manifest twice with no stderr' do
|
|
expect(apply_manifest(pp, :catch_failures => true).stderr).to eq("")
|
|
expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("")
|
|
end
|
|
|
|
describe file('/tmp/concat/file') do
|
|
it { should be_linked_to '/tmp/concat/dangling' }
|
|
end
|
|
|
|
describe file('/tmp/concat/dangling') do
|
|
# XXX serverspec does not have a matcher for 'exists'
|
|
it { should_not be_file }
|
|
it { should_not be_directory }
|
|
end
|
|
end
|
|
|
|
context 'should succeed' do
|
|
# XXX the core puppet file type will replace a symlink with a plain file
|
|
# when using ensure => present and source => ... but it will not when using
|
|
# ensure => present and content => ...; this is somewhat confusing behavior
|
|
before(:all) do
|
|
shell('mkdir -p /tmp/concat')
|
|
shell('ln -s /tmp/concat/dangling /tmp/concat/file')
|
|
end
|
|
after(:all) do
|
|
shell('rm -rf /tmp/concat /var/lib/puppet/concat')
|
|
end
|
|
|
|
pp = <<-EOS
|
|
concat { '/tmp/concat/file':
|
|
replace => true,
|
|
}
|
|
|
|
concat::fragment { '1':
|
|
target => '/tmp/concat/file',
|
|
content => '1',
|
|
}
|
|
|
|
concat::fragment { '2':
|
|
target => '/tmp/concat/file',
|
|
content => '2',
|
|
}
|
|
EOS
|
|
|
|
it 'applies the manifest twice with no stderr' do
|
|
expect(apply_manifest(pp, :catch_failures => true).stderr).to eq("")
|
|
expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("")
|
|
end
|
|
|
|
describe file('/tmp/concat/file') do
|
|
it { should be_file }
|
|
it { should contain '1' }
|
|
it { should contain '2' }
|
|
end
|
|
end
|
|
end # symlink
|
|
|
|
context 'directory' do
|
|
context 'should not succeed' do
|
|
before(:all) do
|
|
shell('mkdir -p /tmp/concat/file')
|
|
end
|
|
after(:all) do
|
|
shell('rm -rf /tmp/concat /var/lib/puppet/concat')
|
|
end
|
|
|
|
pp = <<-EOS
|
|
concat { '/tmp/concat/file': }
|
|
|
|
concat::fragment { '1':
|
|
target => '/tmp/concat/file',
|
|
content => '1',
|
|
}
|
|
|
|
concat::fragment { '2':
|
|
target => '/tmp/concat/file',
|
|
content => '2',
|
|
}
|
|
EOS
|
|
|
|
it 'applies the manifest twice with stderr for changing to file' do
|
|
expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/change from directory to file failed/)
|
|
expect(apply_manifest(pp, :expect_failures => true).stderr).to match(/change from directory to file failed/)
|
|
end
|
|
|
|
describe file('/tmp/concat/file') do
|
|
it { should be_directory }
|
|
end
|
|
end
|
|
|
|
# XXX concat's force param currently enables the creation of empty files
|
|
# when there are no fragments, and the replace param will only replace
|
|
# files and symlinks, not directories. The semantics either need to be
|
|
# changed, extended, or a new param introduced to control directory
|
|
# replacement.
|
|
context 'should succeed', :pending => 'not yet implemented' do
|
|
before(:all) do
|
|
shell('mkdir -p /tmp/concat/file')
|
|
end
|
|
after(:all) do
|
|
shell('rm -rf /tmp/concat /var/lib/puppet/concat')
|
|
end
|
|
|
|
pp = <<-EOS
|
|
concat { '/tmp/concat/file':
|
|
force => true,
|
|
}
|
|
|
|
concat::fragment { '1':
|
|
target => '/tmp/concat/file',
|
|
content => '1',
|
|
}
|
|
|
|
concat::fragment { '2':
|
|
target => '/tmp/concat/file',
|
|
content => '2',
|
|
}
|
|
EOS
|
|
|
|
it 'applies the manifest twice with no stderr' do
|
|
expect(apply_manifest(pp, :catch_failures => true).stderr).to eq("")
|
|
expect(apply_manifest(pp, :catch_changes => true).stderr).to eq("")
|
|
end
|
|
|
|
describe file('/tmp/concat/file') do
|
|
it { should be_file }
|
|
it { should contain '1' }
|
|
end
|
|
end
|
|
end # directory
|
|
end
|