Merge pull request #54 from bodepd/dev

minor updates
This commit is contained in:
Dan Bode 2012-03-30 23:47:13 -07:00
commit 3f8f357acc
4 changed files with 175 additions and 24 deletions

1
TODO Normal file
View File

@ -0,0 +1 @@
cert support has only been added for Redhat. Should this be added for Ubuntu?

View File

@ -2,6 +2,7 @@ class nova(
# this is how to query all resources from our clutser
$nova_cluster_id='localcluster',
$sql_connection = false,
# TODO maybe this should default to glance?
$image_service = 'nova.image.local.LocalImageService',
# these glance params should be optional
# this should probably just be configured as a glance client
@ -54,7 +55,7 @@ class nova(
# allowing a resource to serve as a point where the configuration of nova begins
anchor { 'nova-start': }
package { ["python-nova"]:
package { "python-nova":
ensure => present,
require => Package["python-greenlet"]
}
@ -78,7 +79,7 @@ class nova(
}
file { $logdir:
ensure => directory,
mode => '751',
mode => '0751',
}
file { '/etc/nova/nova.conf':
mode => '0640',
@ -97,6 +98,7 @@ class nova(
# query out the config for our db connection
# TODO - I am not sure if resource collection should be the default
if $sql_connection {
nova_config { 'sql_connection': value => $sql_connection }
} else{

View File

@ -0,0 +1,40 @@
require 'spec_helper'
describe 'nova::cert' do
let :pre_condition do
'include nova'
end
describe 'on debian platforms' do
let :facts do
{ :osfamily => 'Debian' }
end
it { should contain_service('nova-cert').with(
'name' => 'openstack-nova-cert',
'ensure' => 'stopped',
'enable' => false
)}
describe 'with enabled as true' do
let :params do
{:enabled => true}
end
it { should contain_service('nova-cert').with(
'name' => 'openstack-nova-cert',
'ensure' => 'running',
'enable' => true
)}
end
end
describe 'on rhel' do
let :facts do
{ :osfamily => 'RedHat' }
end
it { should contain_service('nova-cert').with(
'name' => 'openstack-nova-cert',
'ensure' => 'stopped',
'enable' => false
)}
it { should_not contain_package('nova-network') }
end
end

View File

@ -5,29 +5,137 @@ describe 'nova' do
{ :osfamily => 'Debian' }
end
it do
should contain_group('nova').with(
describe 'with default parameters' do
it { should contain_package('python').with_ensure('present') }
it { should contain_package('python-greenlet').with(
'ensure' => 'present',
'system' => 'true',
'require' => 'Package[nova-common]'
)
end
it do
should contain_user('nova').with(
'ensure' => 'present',
'gid' => 'nova',
'system' => 'true',
'require' => 'Package[nova-common]'
)
end
describe "When platform is RedHat" do
let :facts do
{:osfamily => 'RedHat'}
end
it { should contain_package('nova-common').with(
'name' => 'openstack-nova',
'ensure' => 'present'
'require' => 'Package[python]'
)}
it { should contain_package('python-nova').with(
'ensure' => 'present',
'require' => 'Package[python-greenlet]'
)}
it { should contain_group('nova').with(
'ensure' => 'present',
'system' => 'true',
'require' => 'Package[nova-common]'
)}
it { should contain_user('nova').with(
'ensure' => 'present',
'gid' => 'nova',
'system' => 'true',
'require' => 'Package[nova-common]'
) }
it { should contain_file('/var/log/nova').with(
'ensure' => 'directory',
'mode' => '0751',
'owner' => 'nova',
'group' => 'nova',
'require' => 'Package[nova-common]'
)}
it { should contain_file('/etc/nova/nova.conf').with(
'mode' => '0640',
'owner' => 'nova',
'group' => 'nova',
'require' => 'Package[nova-common]'
)}
it { should contain_exec('nova-db-sync').with(
'command' => '/usr/bin/nova-manage db sync',
'refreshonly' => true
)}
it { should contain_exec('networking-refresh').with(
'command' => '/sbin/ifdown -a ; /sbin/ifup -a',
'refreshonly' => true
)}
it { should_not contain_nova_config('sql_connection') }
it { should contain_nova_config('verbose').with_value(false) }
it { should contain_nova_config('nodaemon').with_value('false') }
it { should contain_nova_config('logdir').with_value('/var/log/nova') }
it { should contain_nova_config('image_service').with_value('nova.image.local.LocalImageService') }
it { should contain_nova_config('allow_admin_api').with_value('false') }
it { should contain_nova_config('rabbit_host').with_value('localhost') }
it { should contain_nova_config('rabbit_password').with_value('guest') }
it { should contain_nova_config('rabbit_port').with_value('5672') }
it { should contain_nova_config('rabbit_userid').with_value('guest') }
it { should contain_nova_config('rabbit_virtual_host').with_value('/') }
it { should contain_nova_config('state_path').with_value('/var/lib/nova') }
it { should contain_nova_config('lock_path').with_value('/var/lock/nova') }
it { should contain_nova_config('service_down_time').with_value('60') }
it { should contain_nova_config('network_manager').with_value('nova.network.manager.FlatManager') }
it { should_not contain_nova_config('dhcpbridge').with_value('/usr/bin/nova-dhcpbridge') }
it { should_not contain_nova_config('dhcpbridge_flagfile').with_value('/etc/nova/nova.conf') }
it { should contain_nova_config('flat_network_bridge').with_value('br100') }
it { should contain_nova_config('use_deprecated_auth').with_value('true') }
it { should contain_nova_config('root_helper').with_value('sudo') }
describe 'with parameters supplied' do
let :params do
{
'sql_connection' => 'mysql://user:pass@db/db',
'verbose' => true,
'nodaemon' => true,
'logdir' => '/var/log/nova2',
'image_service' => 'nova.image.glance.GlanceImageService',
'allow_admin_api' => true,
'rabbit_host' => 'rabbit',
'rabbit_userid' => 'rabbit_user',
'rabbit_port' => '5672',
'rabbit_password' => 'password',
'lock_path' => '/var/locky/path',
'state_path' => '/var/lib/nova2',
'service_down_time' => '120',
'network_manager' => 'nova.network.manager.FlatDHCPManager'
}
end
it { should contain_nova_config('sql_connection').with_value('mysql://user:pass@db/db') }
it { should contain_nova_config('verbose').with_value(true) }
it { should contain_nova_config('nodaemon').with_value(true) }
it { should contain_nova_config('logdir').with_value('/var/log/nova2') }
# glance config
it { should contain_nova_config('image_service').with_value('nova.image.glance.GlanceImageService') }
it { should contain_nova_config('glance_api_servers').with_value('localhost:9292') }
it { should contain_nova_config('glance_host').with_value('localhost') }
it { should contain_nova_config('glance_port').with_value('9292') }
it { should contain_nova_config('allow_admin_api').with_value(true) }
it { should contain_nova_config('rabbit_host').with_value('rabbit') }
it { should contain_nova_config('rabbit_password').with_value('password') }
it { should contain_nova_config('rabbit_port').with_value('5672') }
it { should contain_nova_config('rabbit_userid').with_value('rabbit_user') }
it { should contain_nova_config('rabbit_virtual_host').with_value('/') }
it { should contain_nova_config('state_path').with_value('/var/lib/nova2') }
it { should contain_nova_config('lock_path').with_value('/var/locky/path') }
it { should contain_nova_config('service_down_time').with_value('120') }
it { should contain_nova_config('network_manager').with_value('nova.network.manager.FlatDHCPManager') }
it { should contain_nova_config('dhcpbridge').with_value('/usr/bin/nova-dhcpbridge') }
it { should contain_nova_config('dhcpbridge_flagfile').with_value('/etc/nova/nova.conf') }
it { should contain_nova_config('use_deprecated_auth').with_value(true) }
end
describe "When platform is RedHat" do
let :facts do
{:osfamily => 'RedHat'}
end
it { should contain_package('nova-common').with(
'name' => 'openstack-nova',
'ensure' => 'present'
)}
end
end
end