require 'spec_helper' describe 'cinder' do let :req_params do { :database_connection => 'mysql+pymysql://user:password@host/database', :lock_path => '/var/lock/cinder', } end shared_examples 'cinder' do context 'with only required params' do let :params do req_params end it { should contain_class('cinder::params') } it { should contain_class('mysql::bindings::python') } it { should contain_resources('cinder_config').with_purge(false) } it { should contain_cinder_config('DEFAULT/transport_url').with(:value => '') should contain_cinder_config('DEFAULT/rpc_response_timeout').with(:value => '') should contain_cinder_config('DEFAULT/control_exchange').with(:value => 'openstack') should contain_cinder_config('DEFAULT/report_interval').with(:value => '') should contain_cinder_config('DEFAULT/service_down_time').with(:value => '') should contain_cinder_config('oslo_messaging_rabbit/rabbit_ha_queues').with(:value => '') should contain_cinder_config('oslo_messaging_rabbit/heartbeat_timeout_threshold').with_value('') should contain_cinder_config('oslo_messaging_rabbit/heartbeat_rate').with_value('') should contain_cinder_config('oslo_messaging_rabbit/kombu_reconnect_delay').with(:value => '') should contain_cinder_config('oslo_messaging_rabbit/kombu_failover_strategy').with(:value => '') should contain_cinder_config('oslo_messaging_rabbit/kombu_compression').with(:value => '') should contain_cinder_config('DEFAULT/storage_availability_zone').with(:value => 'nova') should contain_cinder_config('DEFAULT/default_availability_zone').with(:value => 'nova') should contain_cinder_config('DEFAULT/allow_availability_zone_fallback').with(:value => '') should contain_cinder_config('DEFAULT/api_paste_config').with(:value => '/etc/cinder/api-paste.ini') should contain_cinder_config('DEFAULT/host').with_value('') should contain_cinder_config('DEFAULT/enable_new_services').with_value('') should contain_cinder_config('oslo_concurrency/lock_path').with(:value => '/var/lock/cinder') # backend_host should not be written to DEFAULT section should_not contain_cinder_config('DEFAULT/backend_host') } end context 'with enable ha queues' do let :params do req_params.merge( :rabbit_ha_queues => true ) end it { should contain_cinder_config('oslo_messaging_rabbit/rabbit_ha_queues').with_value(true) } end context 'with rabbitmq heartbeats' do let :params do req_params.merge( :rabbit_heartbeat_timeout_threshold => '60', :rabbit_heartbeat_rate => '10' ) end it { should contain_cinder_config('oslo_messaging_rabbit/heartbeat_timeout_threshold').with_value('60') } it { should contain_cinder_config('oslo_messaging_rabbit/heartbeat_rate').with_value('10') } end context 'with SSL enabled with kombu' do let :params do req_params.merge!({ :rabbit_use_ssl => true, :kombu_ssl_ca_certs => '/path/to/ssl/ca/certs', :kombu_ssl_certfile => '/path/to/ssl/cert/file', :kombu_ssl_keyfile => '/path/to/ssl/keyfile', :kombu_ssl_version => 'TLSv1' }) end it { should contain_oslo__messaging__rabbit('cinder_config').with( :rabbit_use_ssl => true, :kombu_ssl_ca_certs => '/path/to/ssl/ca/certs', :kombu_ssl_certfile => '/path/to/ssl/cert/file', :kombu_ssl_keyfile => '/path/to/ssl/keyfile', :kombu_ssl_version => 'TLSv1' )} end context 'with SSL enabled without kombu' do let :params do req_params.merge!({ :rabbit_use_ssl => true, }) end it { should contain_oslo__messaging__rabbit('cinder_config').with( :rabbit_use_ssl => true, )} end context 'with SSL disabled' do let :params do req_params.merge!({ :rabbit_use_ssl => false, :kombu_ssl_ca_certs => '', :kombu_ssl_certfile => '', :kombu_ssl_keyfile => '', :kombu_ssl_version => '' }) end it { should contain_oslo__messaging__rabbit('cinder_config').with( :rabbit_use_ssl => false, :kombu_ssl_ca_certs => '', :kombu_ssl_certfile => '', :kombu_ssl_keyfile => '', :kombu_ssl_version => '' )} end context 'with different lock_path' do let :params do req_params.merge!( :lock_path => '/var/run/cinder.locks' ) end it { should contain_cinder_config('oslo_concurrency/lock_path').with_value('/var/run/cinder.locks') } end context 'with amqp_durable_queues disabled' do let :params do req_params end it { should contain_cinder_config('oslo_messaging_rabbit/amqp_durable_queues').with_value('') } end context 'with amqp_durable_queues enabled' do let :params do req_params.merge({ :amqp_durable_queues => true, }) end it { should contain_cinder_config('oslo_messaging_rabbit/amqp_durable_queues').with_value(true) } end context 'with amqp defaults' do it { should contain_cinder_config('oslo_messaging_amqp/server_request_prefix').with_value('') should contain_cinder_config('oslo_messaging_amqp/broadcast_prefix').with_value('') should contain_cinder_config('oslo_messaging_amqp/group_request_prefix').with_value('') should contain_cinder_config('oslo_messaging_amqp/container_name').with_value('') should contain_cinder_config('oslo_messaging_amqp/idle_timeout').with_value('') should contain_cinder_config('oslo_messaging_amqp/trace').with_value('') should contain_cinder_config('oslo_messaging_amqp/ssl_ca_file').with_value('') should contain_cinder_config('oslo_messaging_amqp/ssl_cert_file').with_value('') should contain_cinder_config('oslo_messaging_amqp/ssl_key_file').with_value('') should contain_cinder_config('oslo_messaging_amqp/ssl_key_password').with_value('') should contain_cinder_config('oslo_messaging_amqp/allow_insecure_clients').with_value('') should contain_cinder_config('oslo_messaging_amqp/sasl_mechanisms').with_value('') should contain_cinder_config('oslo_messaging_amqp/sasl_config_dir').with_value('') should contain_cinder_config('oslo_messaging_amqp/sasl_config_name').with_value('') should contain_cinder_config('oslo_messaging_amqp/username').with_value('') should contain_cinder_config('oslo_messaging_amqp/password').with_value('') } end context 'with amqp overrides' do let :params do { :amqp_idle_timeout => '60', :amqp_trace => true, :amqp_ssl_ca_file => '/path/to/ca.cert', :amqp_ssl_cert_file => '/path/to/certfile', :amqp_ssl_key_file => '/path/to/key', :amqp_username => 'amqp_user', :amqp_password => 'password', } end it { should contain_cinder_config('oslo_messaging_amqp/server_request_prefix').with_value('') should contain_cinder_config('oslo_messaging_amqp/broadcast_prefix').with_value('') should contain_cinder_config('oslo_messaging_amqp/group_request_prefix').with_value('') should contain_cinder_config('oslo_messaging_amqp/container_name').with_value('') should contain_cinder_config('oslo_messaging_amqp/idle_timeout').with_value('60') should contain_cinder_config('oslo_messaging_amqp/trace').with_value('true') should contain_cinder_config('oslo_messaging_amqp/ssl_ca_file').with_value('/path/to/ca.cert') should contain_cinder_config('oslo_messaging_amqp/ssl_cert_file').with_value('/path/to/certfile') should contain_cinder_config('oslo_messaging_amqp/ssl_key_file').with_value('/path/to/key') should contain_cinder_config('oslo_messaging_amqp/allow_insecure_clients').with_value('') should contain_cinder_config('oslo_messaging_amqp/sasl_mechanisms').with_value('') should contain_cinder_config('oslo_messaging_amqp/sasl_config_dir').with_value('') should contain_cinder_config('oslo_messaging_amqp/sasl_config_name').with_value('') should contain_cinder_config('oslo_messaging_amqp/username').with_value('amqp_user') should contain_cinder_config('oslo_messaging_amqp/password').with_value('password') } end context 'with postgresql' do let :params do { :database_connection => 'postgresql://user:drowssap@host/database', } end it { should_not contain_class('mysql::python') } it { should_not contain_class('mysql::bindings') } it { should_not contain_class('mysql::bindings::python') } end context 'with APIs set for Mitaka (proposed)' do let :params do { :enable_v3_api => true, } end it { should contain_cinder_config('DEFAULT/enable_v3_api').with_value(true) } end context 'with image_conversion_dir' do let :params do req_params.merge({ :image_conversion_dir => '/tmp/foo', }) end it { should contain_cinder_config('DEFAULT/image_conversion_dir').with_value('/tmp/foo') } end context 'with host and enable_new_services' do let :params do req_params.merge({ :host => 'mystring', :enable_new_services => true, }) end it { should contain_cinder_config('DEFAULT/host').with_value('mystring') } it { should contain_cinder_config('DEFAULT/enable_new_services').with_value(true) } end context 'with transport_url' do let :params do req_params.merge({ :default_transport_url => 'rabbit://rabbit_user:password@localhost:5673', }) end it { should contain_cinder_config('DEFAULT/transport_url').with_value('rabbit://rabbit_user:password@localhost:5673') } 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 it_behaves_like 'cinder' end end end