Merge "db: Use postgresql lib class for psycopg package"
This commit is contained in:
@@ -65,6 +65,8 @@ class nova::db (
|
|||||||
$database_max_overflow = 20,
|
$database_max_overflow = 20,
|
||||||
) {
|
) {
|
||||||
|
|
||||||
|
include ::nova::params
|
||||||
|
|
||||||
# NOTE(spredzy): In order to keep backward compatibility we rely on the pick function
|
# NOTE(spredzy): In order to keep backward compatibility we rely on the pick function
|
||||||
# to use nova::<myparam> first the nova::db::<myparam>
|
# to use nova::<myparam> first the nova::db::<myparam>
|
||||||
$database_connection_real = pick($::nova::database_connection, $database_connection)
|
$database_connection_real = pick($::nova::database_connection, $database_connection)
|
||||||
@@ -88,10 +90,11 @@ class nova::db (
|
|||||||
require 'mysql::bindings::python'
|
require 'mysql::bindings::python'
|
||||||
}
|
}
|
||||||
/^postgresql:\/\//: {
|
/^postgresql:\/\//: {
|
||||||
$backend_package = $::neutron::params::psycopg_package_name
|
$backend_package = false
|
||||||
|
require 'postgresql::lib::python'
|
||||||
}
|
}
|
||||||
/^sqlite:\/\//: {
|
/^sqlite:\/\//: {
|
||||||
$backend_package = $::neutron::params::sqlite_package_name
|
$backend_package = $::nova::params::sqlite_package_name
|
||||||
}
|
}
|
||||||
default: {
|
default: {
|
||||||
fail('Unsupported backend configured')
|
fail('Unsupported backend configured')
|
||||||
|
@@ -26,7 +26,6 @@ class nova::params {
|
|||||||
$vncproxy_package_name = 'openstack-nova-novncproxy'
|
$vncproxy_package_name = 'openstack-nova-novncproxy'
|
||||||
$serialproxy_package_name = 'openstack-nova-serialproxy'
|
$serialproxy_package_name = 'openstack-nova-serialproxy'
|
||||||
$spicehtml5proxy_package_name = 'openstack-nova-console'
|
$spicehtml5proxy_package_name = 'openstack-nova-console'
|
||||||
$psycopg_package_name = 'python-psycopg2'
|
|
||||||
$sqlite_package_name = undef
|
$sqlite_package_name = undef
|
||||||
# service names
|
# service names
|
||||||
$api_service_name = 'openstack-nova-api'
|
$api_service_name = 'openstack-nova-api'
|
||||||
@@ -82,7 +81,6 @@ class nova::params {
|
|||||||
$scheduler_package_name = 'nova-scheduler'
|
$scheduler_package_name = 'nova-scheduler'
|
||||||
$tgt_package_name = 'tgt'
|
$tgt_package_name = 'tgt'
|
||||||
$serialproxy_package_name = 'nova-serialproxy'
|
$serialproxy_package_name = 'nova-serialproxy'
|
||||||
$psycopg_package_name = 'python-psycopg2'
|
|
||||||
$sqlite_package_name = 'python-pysqlite2'
|
$sqlite_package_name = 'python-pysqlite2'
|
||||||
# service names
|
# service names
|
||||||
$api_service_name = 'nova-api'
|
$api_service_name = 'nova-api'
|
||||||
|
@@ -33,19 +33,59 @@ describe 'nova::db' do
|
|||||||
it { is_expected.to contain_nova_config('database/retry_interval').with_value('10') }
|
it { is_expected.to contain_nova_config('database/retry_interval').with_value('10') }
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
context 'with postgresql backend' do
|
||||||
|
let :params do
|
||||||
|
{ :database_connection => 'postgresql://nova:nova@localhost/nova', }
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'install the proper backend package' do
|
||||||
|
is_expected.to contain_package('python-psycopg2').with(:ensure => 'present')
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'with incorrect database_connection string' do
|
||||||
|
let :params do
|
||||||
|
{ :database_connection => 'redis://nova:nova@localhost/nova', }
|
||||||
|
end
|
||||||
|
|
||||||
|
it_raises 'a Puppet::Error', /validate_re/
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'on Debian platforms' do
|
context 'on Debian platforms' do
|
||||||
let :facts do
|
let :facts do
|
||||||
{ :osfamily => 'Debian' }
|
{ :osfamily => 'Debian',
|
||||||
|
:operatingsystem => 'Debian',
|
||||||
|
:operatingsystemrelease => 'jessie',
|
||||||
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'nova::db'
|
it_configures 'nova::db'
|
||||||
|
|
||||||
|
context 'with sqlite backend' do
|
||||||
|
let :params do
|
||||||
|
{ :database_connection => 'sqlite:///var/lib/nova/nova.sqlite', }
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'install the proper backend package' do
|
||||||
|
is_expected.to contain_package('nova-backend-package').with(
|
||||||
|
:ensure => 'present',
|
||||||
|
:name => 'python-pysqlite2',
|
||||||
|
:tag => 'openstack'
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'on Redhat platforms' do
|
context 'on Redhat platforms' do
|
||||||
let :facts do
|
let :facts do
|
||||||
{ :osfamily => 'RedHat' }
|
{ :osfamily => 'RedHat',
|
||||||
|
:operatingsystemrelease => '7.1',
|
||||||
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
it_configures 'nova::db'
|
it_configures 'nova::db'
|
||||||
|
Reference in New Issue
Block a user