2015-03-05 01:34:52 +01:00
|
|
|
require 'spec_helper_acceptance'
|
|
|
|
|
|
|
|
describe 'remote-access', :unless => UNSUPPORTED_PLATFORMS.include?(fact('osfamily')) do
|
2015-08-27 17:02:36 +02:00
|
|
|
before do
|
|
|
|
skip "These tests require the spec/acceptance/nodesets/centos-64-x64-2-hosts nodeset"
|
|
|
|
end
|
2015-03-05 01:34:52 +01:00
|
|
|
|
2015-08-27 17:02:36 +02:00
|
|
|
describe "configuring multi-node postgresql" do
|
2015-03-05 01:34:52 +01:00
|
|
|
|
2015-08-27 17:02:36 +02:00
|
|
|
# Get the database's IP to connect to from the database
|
|
|
|
let(:database_ip_address) do
|
|
|
|
hosts_as('database').inject({}) do |memo,host|
|
|
|
|
fact_on host, "ipaddress_eth1"
|
2015-03-05 01:34:52 +01:00
|
|
|
end
|
2015-08-27 17:02:36 +02:00
|
|
|
end
|
2015-03-05 01:34:52 +01:00
|
|
|
|
2015-08-27 17:02:36 +02:00
|
|
|
hosts_as('database').each do |host|
|
|
|
|
it "should be able to configure a host as database on #{host}" do
|
|
|
|
pp = <<-EOS
|
|
|
|
# Stop firewall so we can easily connect
|
|
|
|
service {'iptables':
|
|
|
|
ensure => 'stopped',
|
|
|
|
}
|
2015-03-05 01:34:52 +01:00
|
|
|
|
2015-08-27 17:02:36 +02:00
|
|
|
class { 'postgresql::server':
|
|
|
|
ip_mask_allow_all_users => '0.0.0.0/0',
|
|
|
|
listen_addresses => '*',
|
|
|
|
}
|
2015-03-05 01:34:52 +01:00
|
|
|
|
2015-08-27 17:02:36 +02:00
|
|
|
postgresql::server::db { 'puppet':
|
|
|
|
user => 'puppet',
|
|
|
|
password => postgresql_password('puppet', 'puppet'),
|
|
|
|
}
|
2015-03-05 01:34:52 +01:00
|
|
|
|
2015-08-27 17:02:36 +02:00
|
|
|
postgresql::server::pg_hba_rule { 'allow full yolo access password':
|
|
|
|
type => 'host',
|
|
|
|
database => 'all',
|
|
|
|
user => 'all',
|
|
|
|
address => '0.0.0.0/0',
|
|
|
|
auth_method => 'password',
|
|
|
|
order => '002',
|
|
|
|
}
|
|
|
|
EOS
|
|
|
|
apply_manifest_on(host, pp, :catch_failures => true)
|
2015-03-05 01:34:52 +01:00
|
|
|
end
|
2015-08-27 17:02:36 +02:00
|
|
|
end
|
2015-03-05 01:34:52 +01:00
|
|
|
|
2015-08-27 17:02:36 +02:00
|
|
|
hosts_as('client').each do |host|
|
|
|
|
it "should be able to configure a host as client on #{host} and then access database" do
|
|
|
|
pp = <<-EOS
|
|
|
|
class { 'postgresql::client':}
|
2015-03-05 01:34:52 +01:00
|
|
|
|
2015-08-27 17:02:36 +02:00
|
|
|
$connection_settings = {
|
|
|
|
'PGUSER' => "puppet",
|
|
|
|
'PGPASSWORD' => "puppet",
|
|
|
|
'PGHOST' => "#{database_ip_address}",
|
|
|
|
'PGPORT' => "5432",
|
|
|
|
'PGDATABASE' => "puppet",
|
|
|
|
}
|
2015-03-05 01:34:52 +01:00
|
|
|
|
2015-08-27 17:02:36 +02:00
|
|
|
postgresql_psql { 'run using connection_settings':
|
|
|
|
command => 'select 1',
|
|
|
|
psql_user => 'root',
|
|
|
|
psql_group => 'root',
|
|
|
|
connect_settings => $connection_settings,
|
|
|
|
}
|
|
|
|
EOS
|
|
|
|
apply_manifest_on(host, pp, :catch_failures => true)
|
2015-03-05 01:34:52 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2015-08-27 17:02:36 +02:00
|
|
|
end
|