123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607 |
- require 'spec_helper'
- describe 'nova' do
- shared_examples 'nova' do
- context 'with default parameters' do
- it 'contains the logging class' do
- is_expected.to contain_class('nova::logging')
- end
- it 'installs packages' do
- is_expected.to contain_package('python-nova').with(
- :ensure => 'present',
- :tag => ['openstack', 'nova-package']
- )
- is_expected.to contain_package('nova-common').with(
- :name => platform_params[:nova_common_package],
- :ensure => 'present',
- :tag => ['openstack', 'nova-package']
- )
- end
- it 'configures rootwrap' do
- is_expected.to contain_nova_config('DEFAULT/rootwrap_config').with_value('/etc/nova/rootwrap.conf')
- end
- it { is_expected.to contain_exec('networking-refresh').with(
- :command => '/sbin/ifdown -a ; /sbin/ifup -a',
- :refreshonly => true
- )}
- it 'configures image service' do
- is_expected.to contain_nova_config('DEFAULT/image_service').with_value('nova.image.glance.GlanceImageService')
- is_expected.to contain_nova_config('glance/api_servers').with_value('http://localhost:9292')
- end
- it 'configures auth_strategy' do
- is_expected.to contain_nova_config('api/auth_strategy').with_value('keystone')
- is_expected.to_not contain_nova_config('DEFAULT/use_deprecated_auth').with_value(false)
- end
- it 'configures rabbit' do
- is_expected.to contain_nova_config('DEFAULT/rpc_backend').with_value('rabbit')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_host').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_password').with_value('<SERVICE DEFAULT>').with_secret(true)
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_port').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_userid').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_virtual_host').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/heartbeat_timeout_threshold').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/heartbeat_rate').with_value('<SERVICE DEFAULT>')
- end
- it 'configures various things' do
- is_expected.to contain_nova_config('DEFAULT/state_path').with_value('/var/lib/nova')
- is_expected.to contain_nova_config('oslo_concurrency/lock_path').with_value(platform_params[:lock_path])
- is_expected.to contain_nova_config('DEFAULT/service_down_time').with_value('60')
- is_expected.to contain_nova_config('DEFAULT/rootwrap_config').with_value('/etc/nova/rootwrap.conf')
- is_expected.to contain_nova_config('DEFAULT/report_interval').with_value('10')
- is_expected.to contain_nova_config('os_vif_linux_bridge/use_ipv6').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('DEFAULT/transport_url').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('DEFAULT/rpc_response_timeout').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('cinder/os_region_name').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('cinder/catalog_info').with('value' => 'volumev2:cinderv2:publicURL')
- is_expected.to contain_nova_config('DEFAULT/cpu_allocation_ratio').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('DEFAULT/ram_allocation_ratio').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('DEFAULT/disk_allocation_ratio').with_value('<SERVICE DEFAULT>')
- end
- it 'configures block_device_allocate params' do
- is_expected.to contain_nova_config('DEFAULT/block_device_allocate_retries').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('DEFAULT/block_device_allocate_retries_interval').with_value('<SERVICE DEFAULT>')
- end
- end
- context 'with overridden parameters' do
- let :params do
- { :debug => true,
- :log_dir => '/var/log/nova2',
- :image_service => 'nova.image.local.LocalImageService',
- :default_transport_url => 'rabbit://rabbit_user:password@localhost:5673',
- :rpc_response_timeout => '30',
- :rpc_backend => 'rabbit',
- :rabbit_host => 'rabbit',
- :rabbit_userid => 'rabbit_user',
- :rabbit_port => '5673',
- :rabbit_password => 'password',
- :rabbit_heartbeat_timeout_threshold => '60',
- :rabbit_heartbeat_rate => '10',
- :lock_path => '/var/locky/path',
- :state_path => '/var/lib/nova2',
- :service_down_time => '120',
- :auth_strategy => 'foo',
- :ensure_package => '2012.1.1-15.el6',
- :host => 'test-001.example.org',
- :notification_transport_url => 'rabbit://rabbit_user:password@localhost:5673',
- :notification_driver => 'ceilometer.compute.nova_notifier',
- :notification_topics => 'openstack',
- :notify_api_faults => true,
- :report_interval => '60',
- :os_region_name => 'MyRegion',
- :use_ipv6 => true,
- :upgrade_level_cells => '1.0.0',
- :upgrade_level_cert => '1.0.0',
- :upgrade_level_compute => '1.0.0',
- :upgrade_level_conductor => '1.0.0',
- :upgrade_level_console => '1.0.0',
- :upgrade_level_consoleauth => '1.0.0',
- :upgrade_level_intercell => '1.0.0',
- :upgrade_level_network => '1.0.0',
- :upgrade_level_scheduler => '1.0.0',
- :purge_config => false,
- :block_device_allocate_retries => '60',
- :block_device_allocate_retries_interval => '3',
- }
- end
- it 'installs packages' do
- is_expected.to contain_package('nova-common').with('ensure' => '2012.1.1-15.el6')
- is_expected.to contain_package('python-nova').with('ensure' => '2012.1.1-15.el6')
- end
- it 'passes purge to resource' do
- is_expected.to contain_resources('nova_config').with({
- :purge => false
- })
- end
- it 'configures image service' do
- is_expected.to contain_nova_config('DEFAULT/image_service').with_value('nova.image.local.LocalImageService')
- is_expected.to_not contain_nova_config('glance/api_servers')
- end
- it 'configures auth_strategy' do
- is_expected.to contain_nova_config('api/auth_strategy').with_value('foo')
- is_expected.to_not contain_nova_config('DEFAULT/use_deprecated_auth').with_value(true)
- end
- it 'configures rabbit' do
- is_expected.to contain_nova_config('DEFAULT/rpc_backend').with_value('rabbit')
- is_expected.to contain_nova_config('DEFAULT/transport_url').with_value('rabbit://rabbit_user:password@localhost:5673')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_host').with_value('rabbit')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_password').with_value('password').with_secret(true)
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_port').with_value('5673')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_userid').with_value('rabbit_user')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_virtual_host').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/heartbeat_timeout_threshold').with_value('60')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/heartbeat_rate').with_value('10')
- end
- it 'configures host' do
- is_expected.to contain_nova_config('DEFAULT/host').with_value('test-001.example.org')
- end
- it 'configures upgrade_levels' do
- is_expected.to contain_nova_config('upgrade_levels/cells').with_value('1.0.0')
- is_expected.to contain_nova_config('upgrade_levels/cert').with_value('1.0.0')
- is_expected.to contain_nova_config('upgrade_levels/compute').with_value('1.0.0')
- is_expected.to contain_nova_config('upgrade_levels/conductor').with_value('1.0.0')
- is_expected.to contain_nova_config('upgrade_levels/console').with_value('1.0.0')
- is_expected.to contain_nova_config('upgrade_levels/consoleauth').with_value('1.0.0')
- is_expected.to contain_nova_config('upgrade_levels/intercell').with_value('1.0.0')
- is_expected.to contain_nova_config('upgrade_levels/network').with_value('1.0.0')
- is_expected.to contain_nova_config('upgrade_levels/scheduler').with_value('1.0.0')
- end
- it 'configures various things' do
- is_expected.to contain_nova_config('DEFAULT/state_path').with_value('/var/lib/nova2')
- is_expected.to contain_nova_config('oslo_concurrency/lock_path').with_value('/var/locky/path')
- is_expected.to contain_nova_config('DEFAULT/service_down_time').with_value('120')
- is_expected.to contain_nova_config('DEFAULT/rpc_response_timeout').with_value('30')
- is_expected.to contain_nova_config('oslo_messaging_notifications/transport_url').with_value('rabbit://rabbit_user:password@localhost:5673')
- is_expected.to contain_nova_config('oslo_messaging_notifications/driver').with_value('ceilometer.compute.nova_notifier')
- is_expected.to contain_nova_config('oslo_messaging_notifications/topics').with_value('openstack')
- is_expected.to contain_nova_config('DEFAULT/notify_api_faults').with_value(true)
- is_expected.to contain_nova_config('DEFAULT/report_interval').with_value('60')
- is_expected.to contain_nova_config('os_vif_linux_bridge/use_ipv6').with_value('true')
- is_expected.to contain_nova_config('cinder/os_region_name').with_value('MyRegion')
- end
- context 'with multiple notification_driver' do
- before { params.merge!( :notification_driver => ['ceilometer.compute.nova_notifier', 'nova.openstack.common.notifier.rpc_notifier']) }
- it { is_expected.to contain_nova_config('oslo_messaging_notifications/driver').with_value(
- 'ceilometer.compute.nova_notifier,nova.openstack.common.notifier.rpc_notifier'
- ) }
- end
- it 'configures block_device_allocate params' do
- is_expected.to contain_nova_config('DEFAULT/block_device_allocate_retries').with_value('60')
- is_expected.to contain_nova_config('DEFAULT/block_device_allocate_retries_interval').with_value('3')
- end
- end
- context 'with wrong notify_on_state_change parameter' do
- let :params do
- { :notify_on_state_change => 'vm_status' }
- end
- it 'configures database' do
- is_expected.to contain_nova_config('DEFAULT/notify_on_state_change').with_ensure('absent')
- end
- end
- context 'with notify_on_state_change parameter' do
- let :params do
- { :notify_on_state_change => 'vm_state' }
- end
- it 'configures database' do
- is_expected.to contain_nova_config('DEFAULT/notify_on_state_change').with_value('vm_state')
- end
- end
- context 'with rabbit_hosts parameter' do
- let :params do
- { :rabbit_hosts => ['rabbit:5673', 'rabbit2:5674'] }
- end
- it 'configures rabbit' do
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_host').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_port').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_hosts').with_value('rabbit:5673,rabbit2:5674')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_ha_queues').with_value(true)
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_use_ssl').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_reconnect_delay').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_compression').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/amqp_durable_queues').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_ca_certs').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_certfile').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_keyfile').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_version').with_value('<SERVICE DEFAULT>')
- end
- end
- context 'with rabbit_hosts parameter (one server)' do
- let :params do
- { :rabbit_hosts => ['rabbit:5673'] }
- end
- it 'configures rabbit' do
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_host').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_port').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_hosts').with_value('rabbit:5673')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_ha_queues').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_use_ssl').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_reconnect_delay').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/amqp_durable_queues').with_value('<SERVICE DEFAULT>')
- end
- end
- context 'with kombu_reconnect_delay set to 5.0' do
- let :params do
- { :kombu_reconnect_delay => '5.0' }
- end
- it 'configures rabbit' do
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_reconnect_delay').with_value('5.0')
- end
- end
- context 'with rabbit_ha_queues set to true' do
- let :params do
- { :rabbit_ha_queues => true }
- end
- it 'configures rabbit' do
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_ha_queues').with_value(true)
- end
- end
- context 'with rabbit_ha_queues set to false and with rabbit_hosts' do
- let :params do
- { :rabbit_ha_queues => 'false',
- :rabbit_hosts => ['rabbit:5673'] }
- end
- it 'configures rabbit' do
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_ha_queues').with_value(false)
- end
- end
- context 'with amqp_durable_queues parameter' do
- let :params do
- { :rabbit_hosts => ['rabbit:5673'],
- :amqp_durable_queues => true }
- end
- it 'configures rabbit' do
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_host').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_port').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_hosts').with_value('rabbit:5673')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_ha_queues').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_use_ssl').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/amqp_durable_queues').with_value(true)
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_ca_certs').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_certfile').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_keyfile').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_version').with_value('<SERVICE DEFAULT>')
- end
- end
- context 'with rabbit ssl enabled with kombu' do
- let :params do
- { :rabbit_hosts => ['rabbit:5673'],
- :rabbit_use_ssl => true,
- :kombu_ssl_ca_certs => '/etc/ca.cert',
- :kombu_ssl_certfile => '/etc/certfile',
- :kombu_ssl_keyfile => '/etc/key',
- :kombu_ssl_version => 'TLSv1', }
- end
- it 'configures rabbit' do
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_use_ssl').with_value(true)
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_ca_certs').with_value('/etc/ca.cert')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_certfile').with_value('/etc/certfile')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_keyfile').with_value('/etc/key')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_version').with_value('TLSv1')
- end
- end
- context 'with rabbit ssl enabled without kombu' do
- let :params do
- { :rabbit_hosts => ['rabbit:5673'],
- :rabbit_use_ssl => true, }
- end
- it 'configures rabbit' do
- is_expected.to contain_nova_config('oslo_messaging_rabbit/rabbit_use_ssl').with_value(true)
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_ca_certs').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_certfile').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_keyfile').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_rabbit/kombu_ssl_version').with_value('<SERVICE DEFAULT>')
- end
- end
- context 'with rabbitmq rpc_backend with old parameter' do
- let :params do
- { :rpc_backend => 'nova.openstack.common.rpc.impl_kombu' }
- end
- it { is_expected.to contain_nova_config('DEFAULT/rpc_backend').with_value('rabbit') }
- end
- context 'with amqp rpc_backend default parameters' do
- let :params do
- { :rpc_backend => 'amqp' }
- end
- it 'configures amqp' do
- is_expected.to contain_nova_config('DEFAULT/rpc_backend').with_value('amqp')
- is_expected.to contain_nova_config('oslo_messaging_amqp/server_request_prefix').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/broadcast_prefix').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/group_request_prefix').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/container_name').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/idle_timeout').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/trace').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/ssl_ca_file').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/ssl_cert_file').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/ssl_key_file').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/ssl_key_password').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/allow_insecure_clients').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/sasl_mechanisms').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/sasl_config_dir').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/sasl_config_name').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/username').with_value('<SERVICE DEFAULT>')
- is_expected.to contain_nova_config('oslo_messaging_amqp/password').with_value('<SERVICE DEFAULT>')
- end
- end
- context 'with amqp rpc_backend overriden parameters' do
- let :params do
- { :rpc_backend => 'amqp',
- :amqp_idle_timeout => '60',
- :amqp_trace => true,
- :amqp_ssl_ca_file => '/etc/ca.cert',
- :amqp_ssl_cert_file => '/etc/certfile',
- :amqp_ssl_key_file => '/etc/key',
- :amqp_username => 'amqp_user',
- :amqp_password => 'password',
- }
- end
- it 'configures amqp overide' do
- is_expected.to contain_nova_config('DEFAULT/rpc_backend').with_value('amqp')
- is_expected.to contain_nova_config('oslo_messaging_amqp/idle_timeout').with_value('60')
- is_expected.to contain_nova_config('oslo_messaging_amqp/trace').with_value('true')
- is_expected.to contain_nova_config('oslo_messaging_amqp/ssl_ca_file').with_value('/etc/ca.cert')
- is_expected.to contain_nova_config('oslo_messaging_amqp/ssl_cert_file').with_value('/etc/certfile')
- is_expected.to contain_nova_config('oslo_messaging_amqp/ssl_key_file').with_value('/etc/key')
- is_expected.to contain_nova_config('oslo_messaging_amqp/username').with_value('amqp_user')
- is_expected.to contain_nova_config('oslo_messaging_amqp/password').with_value('password')
- end
- end
- context 'with ssh public key' do
- let :params do
- {
- :nova_public_key => {'type' => 'ssh-rsa',
- 'key' => 'keydata'}
- }
- end
- it 'should install ssh public key' do
- is_expected.to contain_ssh_authorized_key('nova-migration-public-key').with(
- :ensure => 'present',
- :key => 'keydata',
- :type => 'ssh-rsa'
- )
- end
- end
- context 'with ssh public key missing key type' do
- let :params do
- {
- :nova_public_key => {'key' => 'keydata'}
- }
- end
- it 'should raise an error' do
- expect {
- is_expected.to contain_ssh_authorized_key('nova-migration-public-key').with(
- :ensure => 'present',
- :key => 'keydata'
- )
- }.to raise_error Puppet::Error, /You must provide both a key type and key data./
- end
- end
- context 'with ssh public key missing key data' do
- let :params do
- {
- :nova_public_key => {'type' => 'ssh-rsa'}
- }
- end
- it 'should raise an error' do
- expect {
- is_expected.to contain_ssh_authorized_key('nova-migration-public-key').with(
- :ensure => 'present',
- :key => 'keydata'
- )
- }.to raise_error Puppet::Error, /You must provide both a key type and key data./
- end
- end
- context 'with ssh private key' do
- let :params do
- {
- :nova_private_key => {'type' => 'ssh-rsa',
- 'key' => 'keydata'}
- }
- end
- it 'should install ssh private key' do
- is_expected.to contain_file('/var/lib/nova/.ssh/id_rsa').with(
- :content => 'keydata'
- )
- end
- end
- context 'with ssh private key missing key type' do
- let :params do
- {
- :nova_private_key => {'key' => 'keydata'}
- }
- end
- it 'should raise an error' do
- expect {
- is_expected.to contain_file('/var/lib/nova/.ssh/id_rsa').with(
- :content => 'keydata'
- )
- }.to raise_error Puppet::Error, /You must provide both a key type and key data./
- end
- end
- context 'with ssh private key having incorrect key type' do
- let :params do
- {
- :nova_private_key => {'type' => 'invalid',
- 'key' => 'keydata'}
- }
- end
- it 'should raise an error' do
- expect {
- is_expected.to contain_file('/var/lib/nova/.ssh/id_rsa').with(
- :content => 'keydata'
- )
- }.to raise_error Puppet::Error, /Unable to determine name of private key file./
- end
- end
- context 'with ssh private key missing key data' do
- let :params do
- {
- :nova_private_key => {'type' => 'ssh-rsa'}
- }
- end
- it 'should raise an error' do
- expect {
- is_expected.to contain_file('/var/lib/nova/.ssh/id_rsa').with(
- :content => 'keydata'
- )
- }.to raise_error Puppet::Error, /You must provide both a key type and key data./
- end
- end
- context 'with SSL socket options set' do
- let :params do
- {
- :use_ssl => true,
- :enabled_ssl_apis => ['osapi_compute'],
- :cert_file => '/path/to/cert',
- :ca_file => '/path/to/ca',
- :key_file => '/path/to/key',
- }
- end
- it { is_expected.to contain_nova_config('DEFAULT/enabled_ssl_apis').with_value('osapi_compute') }
- it { is_expected.to contain_nova_config('ssl/ca_file').with_value('/path/to/ca') }
- it { is_expected.to contain_nova_config('ssl/cert_file').with_value('/path/to/cert') }
- it { is_expected.to contain_nova_config('ssl/key_file').with_value('/path/to/key') }
- it { is_expected.to contain_nova_config('wsgi/ssl_ca_file').with_value('/path/to/ca') }
- it { is_expected.to contain_nova_config('wsgi/ssl_cert_file').with_value('/path/to/cert') }
- it { is_expected.to contain_nova_config('wsgi/ssl_key_file').with_value('/path/to/key') }
- end
- context 'with SSL socket options set with wrong parameters' do
- let :params do
- {
- :use_ssl => true,
- :enabled_ssl_apis => ['osapi_compute'],
- :ca_file => '/path/to/ca',
- :key_file => '/path/to/key',
- }
- end
- it_raises 'a Puppet::Error', /The cert_file parameter is required when use_ssl is set to true/
- end
- context 'with SSL socket options set to false' do
- let :params do
- {
- :use_ssl => false,
- :enabled_ssl_apis => [],
- :cert_file => false,
- :ca_file => false,
- :key_file => false,
- }
- end
- it { is_expected.to contain_nova_config('DEFAULT/enabled_ssl_apis').with_ensure('absent') }
- it { is_expected.to contain_nova_config('ssl/ca_file').with_ensure('absent') }
- it { is_expected.to contain_nova_config('ssl/cert_file').with_ensure('absent') }
- it { is_expected.to contain_nova_config('ssl/key_file').with_ensure('absent') }
- end
- context 'with allocation ratios set' do
- let :params do
- {
- :cpu_allocation_ratio => 32.0,
- :ram_allocation_ratio => 2.0,
- :disk_allocation_ratio => 1.5,
- }
- end
- it { is_expected.to contain_nova_config('DEFAULT/cpu_allocation_ratio').with_value('32.0') }
- it { is_expected.to contain_nova_config('DEFAULT/ram_allocation_ratio').with_value('2.0') }
- it { is_expected.to contain_nova_config('DEFAULT/disk_allocation_ratio').with_value('1.5') }
- end
- end
- on_supported_os({
- :supported_os => OSDefaults.get_supported_os
- }).each do |os,facts|
- context "on #{os}" do
- let (:facts) do
- facts.merge!(OSDefaults.get_facts())
- end
- case facts[:osfamily]
- when 'Debian'
- let (:platform_params) do
- { :nova_common_package => 'nova-common',
- :lock_path => '/var/lock/nova' }
- end
- when 'RedHat'
- let (:platform_params) do
- { :nova_common_package => 'openstack-nova-common',
- :lock_path => '/var/lib/nova/tmp' }
- end
- end
- it_behaves_like 'nova'
- end
- end
- end
|