Merge pull request #747 from cyberious/default_connect_settings

Fix issues with missing parameters in `server` class
This commit is contained in:
Bryan Jen 2016-03-01 12:10:05 -07:00
commit f1bd5a9063
5 changed files with 14 additions and 14 deletions

View file

@ -41,7 +41,7 @@ PostgreSQL is a high-performance, free, open-source relational database server.
### Getting started with postgresql
To configure a basic default PostgreSQL server, declare the `postgresql::server` class.
To configure a basic default PostgreSQL server, declare the `postgresql::server` class.
```puppet
class { 'postgresql::server': }
@ -182,7 +182,7 @@ require => Postgresql::Server::Role['super2'],
### Create an access rule for pg_hba.conf
To create an access rule for `pg_hba.conf`:
To create an access rule for `pg_hba.conf`:
```puppet
postgresql::server::pg_hba_rule { 'allow application network to access app database':
@ -242,7 +242,7 @@ sslrepli repli1.example.com replication
### Create recovery configuration
To create the recovery configuration file (`recovery.conf`):
To create the recovery configuration file (`recovery.conf`):
```puppet
postgresql::server::recovery{ 'Create a recovery.conf file with the following defined parameters':
@ -535,7 +535,7 @@ Installs the packages containing the development libraries for PostgreSQL and sy
##### `link_pg_config`
If the bin directory used by the PostgreSQL page is not `/usr/bin` or `/usr/local/bin`, symlinks `pg_config` from the package's bin dir into `usr/bin` (not applicable to Debian systems). Set to false to disable this behavior. Valid values: true, false. Default: true.
If the bin directory used by the PostgreSQL page is not `/usr/bin` or `/usr/local/bin`, symlinks `pg_config` from the package's bin dir into `usr/bin` (not applicable to Debian systems). Set to false to disable this behavior. Valid values: true, false. Default: true.
##### `package_ensure`
@ -585,7 +585,7 @@ Specifies whether the package is present. Valid values: 'present', 'absent'. Def
#### postgresql::lib::python
Installs PostgreSQL Python libraries.
Installs PostgreSQL Python libraries.
##### `package_ensure`
@ -605,6 +605,10 @@ The name of the PostgreSQL Python package.
Specifies the name of the default database to connect with. On most systems this is "postgres".
##### `default_connect_settings`
Specifies a hash of environment variables used when connecting to a remote server. Becomes the default for other defined-types. i.e. `postgresql::server::role`
##### `encoding`
Sets the default encoding for all databases created with this module. On certain operating systems this is also used during the `template1` initialization, so it becomes a default outside of the module as well. Default: undef.
@ -627,7 +631,7 @@ Lists strings for access control for connection method, users, databases, IPv6 a
##### `ip_mask_allow_all_users`
Overrides PostgreSQL defaults for remote connections. By default, PostgreSQL does not allow database user accounts to connect via TCP from remote machines. If you'd like to allow this, you can override this setting.
Overrides PostgreSQL defaults for remote connections. By default, PostgreSQL does not allow database user accounts to connect via TCP from remote machines. If you'd like to allow this, you can override this setting.
Set to `0.0.0.0/0` to allow database users to connect from any remote machine, or `192.168.0.0/16` to allow connections from any machine on your local 192.168 subnet. Default: `127.0.0.1/32`.
@ -1035,7 +1039,7 @@ Provides the target for the rule and is generally an internal only property. **U
Allows you to create the content for `recovery.conf`. For more details see the [usage example](#create-recovery-configuration) and the [PostgreSQL documentation](http://www.postgresql.org/docs/current/static/recovery-config.html).
Every parameter value is a string set in the template except `recovery_target_inclusive`, `pause_at_recovery_target`, `standby_mode` and `recovery_min_apply_delay`.
Every parameter value is a string set in the template except `recovery_target_inclusive`, `pause_at_recovery_target`, `standby_mode` and `recovery_min_apply_delay`.
A detailed description of all listed parameters can be found in the [PostgreSQL documentation](http://www.postgresql.org/docs/current/static/recovery-config.html).

View file

@ -27,7 +27,7 @@ class postgresql::globals (
$pg_ident_conf_path = undef,
$postgresql_conf_path = undef,
$recovery_conf_path = undef,
$default_connect_settings = undef,
$default_connect_settings = {},
$pg_hba_conf_defaults = undef,

View file

@ -18,7 +18,7 @@ class postgresql::server (
$service_reload = $postgresql::params::service_reload,
$service_status = $postgresql::params::service_status,
$default_database = $postgresql::params::default_database,
$default_connect_settings = $postgresql::globals::default_connect_settings,
$listen_addresses = $postgresql::params::listen_addresses,
$port = $postgresql::params::port,
$ip_mask_deny_postgres_user = $postgresql::params::ip_mask_deny_postgres_user,

View file

@ -24,8 +24,7 @@ describe 'postgresql::server::database', :type => :define do
it { is_expected.to contain_postgresql_psql("Create db 'test'") }
context "with comment set to 'test comment'" do
let (:params) {{ :comment => 'test comment',
:connect_settings => {} }}
let (:params) {{ :comment => 'test comment' }}
it { is_expected.to contain_postgresql_psql("COMMENT ON DATABASE \"test\" IS 'test comment'").with_connect_settings( {} ) }
end

View file

@ -20,7 +20,6 @@ describe 'postgresql::server::role', :type => :define do
let :params do
{
:password_hash => 'new-pa$s',
:connect_settings => {},
}
end
@ -35,7 +34,6 @@ describe 'postgresql::server::role', :type => :define do
'environment' => "NEWPGPASSWD=new-pa$s",
'unless' => "SELECT rolname FROM pg_roles WHERE rolname='test'",
'port' => "5432",
'connect_settings' => {},
})
end
it 'should have alter role for "test" user with password as ****' do
@ -44,7 +42,6 @@ describe 'postgresql::server::role', :type => :define do
'environment' => "NEWPGPASSWD=new-pa$s",
'unless' => "SELECT usename FROM pg_shadow WHERE usename='test' and passwd='md5b6f7fcbbabb4befde4588a26c1cfd2fa'",
'port' => "5432",
'connect_settings' => {},
})
end