59c1cbfbf8
This is a very very large change to the module. It started out as a fix to add postgresl::server::config_entry, and quickly became a rewrite to fix a lot of ordering issues inherent in the API. Since this changes the Public API it is considered a backwards compatible change. See the upgrading guide in README.md for more details as to what has been modified in this patch. Signed-off-by: Ken Barber <ken@bob.sh>
198 lines
5.4 KiB
Ruby
198 lines
5.4 KiB
Ruby
require 'spec_helper_system'
|
|
|
|
describe 'server:' do
|
|
after :all do
|
|
# Cleanup after tests have ran
|
|
puppet_apply("class { 'postgresql::server': ensure => absent }") do |r|
|
|
r.exit_code.should_not == 1
|
|
end
|
|
end
|
|
|
|
it 'test loading class with no parameters' do
|
|
pp = <<-EOS
|
|
class { 'postgresql::server': }
|
|
EOS
|
|
|
|
puppet_apply(pp) do |r|
|
|
r.exit_code.should_not == 1
|
|
end
|
|
|
|
puppet_apply(pp) do |r|
|
|
r.exit_code.should be_zero
|
|
end
|
|
end
|
|
|
|
describe 'setting postgres password' do
|
|
it 'should install and successfully adjust the password' do
|
|
pp = <<-EOS
|
|
class { 'postgresql::server':
|
|
postgres_password => 'foobarbaz',
|
|
ip_mask_deny_postgres_user => '0.0.0.0/32',
|
|
}
|
|
EOS
|
|
|
|
puppet_apply(pp) do |r|
|
|
[0,2].should include(r.exit_code)
|
|
r.stdout.should =~ /\[set_postgres_postgrespw\]\/returns: executed successfully/
|
|
end
|
|
puppet_apply(pp) do |r|
|
|
r.exit_code.should == 0
|
|
end
|
|
|
|
pp = <<-EOS
|
|
class { 'postgresql::server':
|
|
postgres_password => 'TPSR$$eports!',
|
|
ip_mask_deny_postgres_user => '0.0.0.0/32',
|
|
}
|
|
EOS
|
|
|
|
puppet_apply(pp) do |r|
|
|
[0,2].should include(r.exit_code)
|
|
r.stdout.should =~ /\[set_postgres_postgrespw\]\/returns: executed successfully/
|
|
end
|
|
puppet_apply(pp) do |r|
|
|
r.exit_code.should == 0
|
|
end
|
|
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'server without defaults:' do
|
|
before :all do
|
|
puppet_apply(<<-EOS)
|
|
if($::operatingsystem =~ /Debian|Ubuntu/) {
|
|
# Need to make sure the correct utf8 locale is ready for our
|
|
# non-standard tests
|
|
file { '/etc/locale.gen':
|
|
content => "en_US ISO-8859-1\nen_NG UTF-8\nen_US UTF-8\n",
|
|
}~>
|
|
exec { '/usr/sbin/locale-gen':
|
|
logoutput => true,
|
|
refreshonly => true,
|
|
}
|
|
}
|
|
EOS
|
|
end
|
|
|
|
context 'test installing non-default version of postgresql' do
|
|
after :each do
|
|
# Cleanup
|
|
psql('--command="drop database postgresql_test_db" postgres')
|
|
pp = <<-EOS
|
|
class { 'postgresql::globals':
|
|
version => "9.2",
|
|
manage_package_repo => true,
|
|
service_status => 'service postgresql-9.2 status',
|
|
}
|
|
class { 'postgresql::server':
|
|
ensure => absent,
|
|
}
|
|
EOS
|
|
puppet_apply(pp) do |r|
|
|
r.exit_code.should_not == 1
|
|
end
|
|
end
|
|
|
|
it 'perform installation and create a db' do
|
|
pp = <<-EOS
|
|
class { "postgresql::globals":
|
|
version => "9.2",
|
|
manage_package_repo => true,
|
|
encoding => 'UTF8',
|
|
locale => 'en_US.UTF-8',
|
|
}
|
|
class { "postgresql::server": }
|
|
postgresql::server::db { "postgresql_test_db":
|
|
user => "foo1",
|
|
password => postgresql_password('foo1', 'foo1'),
|
|
}
|
|
EOS
|
|
|
|
puppet_apply(pp) do |r|
|
|
# Currently puppetlabs/apt shows deprecated messages
|
|
#r.stderr.should be_empty
|
|
[2,6].should include(r.exit_code)
|
|
|
|
r.refresh
|
|
|
|
# Currently puppetlabs/apt shows deprecated messages
|
|
#r.stderr.should be_empty
|
|
# It also returns a 4
|
|
[0,4].should include(r.exit_code)
|
|
end
|
|
|
|
psql('postgresql_test_db --command="select datname from pg_database limit 1"')
|
|
end
|
|
end
|
|
|
|
context 'override locale and encoding' do
|
|
after :all do
|
|
puppet_apply "class { 'postgresql::server': ensure => absent }" do |r|
|
|
r.exit_code.should_not == 1
|
|
end
|
|
end
|
|
|
|
it 'perform installation with different locale and encoding' do
|
|
pending('no support for locale parameter with centos 5', :if => (node.facts['osfamily'] == 'RedHat' and node.facts['lsbmajdistrelease'] == '5'))
|
|
pending('no support for initdb with debian/ubuntu', :if => (node.facts['osfamily'] == 'Debian'))
|
|
|
|
pp = <<-EOS
|
|
class { 'postgresql::server':
|
|
locale => 'en_NG',
|
|
encoding => 'UTF8',
|
|
}
|
|
EOS
|
|
|
|
puppet_apply(pp) do |r|
|
|
# Currently puppetlabs/apt shows deprecated messages
|
|
#r.stderr.should be_empty
|
|
# It also returns a 6
|
|
[2,6].should include(r.exit_code)
|
|
|
|
r.refresh
|
|
|
|
# Currently puppetlabs/apt shows deprecated messages
|
|
#r.stderr.should be_empty
|
|
# It also returns a 2
|
|
[0,4].should include(r.exit_code)
|
|
end
|
|
|
|
# Remove db first, if it exists for some reason
|
|
shell('su postgres -c "dropdb test1"')
|
|
shell('su postgres -c "createdb test1"')
|
|
shell('su postgres -c \'psql -c "show lc_ctype" test1\'') do |r|
|
|
r.stdout.should =~ /en_NG/
|
|
end
|
|
|
|
shell('su postgres -c \'psql -c "show lc_collate" test1\'') do |r|
|
|
r.stdout.should =~ /en_NG/
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'server with firewall:' do
|
|
after :all do
|
|
# Cleanup after tests have ran
|
|
puppet_apply("class { 'postgresql::server': ensure => absent }") do |r|
|
|
r.exit_code.should_not == 1
|
|
end
|
|
end
|
|
|
|
context 'test installing postgresql with firewall management on' do
|
|
it 'perform installation and make sure it is idempotent' do
|
|
pp = <<-EOS
|
|
class { "postgresql::server":
|
|
manage_firewall => true,
|
|
}
|
|
EOS
|
|
|
|
puppet_apply(pp) do |r|
|
|
r.exit_code.should == 2
|
|
r.refresh
|
|
r.exit_code.should == 0
|
|
end
|
|
end
|
|
end
|
|
end
|