92180ae9a1
In order to be able to take an action after all the packages of the module have been installed/updated or all the services have been started/restarted, we set a 'glance-package' and 'glance-service' tag for each package and service of this module. At the moment, there is a generic openstack tag that is not specific enough if one wants to take action upon a single module change. Use case : If an action needs to be taken after all the packages have been installed or updated : Package <| tag == 'glance-package' |> -> X Change-Id: If43e27e80500deebf6b758b11541d3d6f50cb129
473 lines
16 KiB
Ruby
473 lines
16 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe 'glance::api' do
|
|
|
|
let :facts do
|
|
{
|
|
:osfamily => 'Debian',
|
|
:processorcount => '7',
|
|
}
|
|
end
|
|
|
|
let :default_params do
|
|
{
|
|
:verbose => false,
|
|
:debug => false,
|
|
:bind_host => '0.0.0.0',
|
|
:bind_port => '9292',
|
|
:registry_host => '0.0.0.0',
|
|
:registry_port => '9191',
|
|
:registry_client_protocol => 'http',
|
|
:log_file => '/var/log/glance/api.log',
|
|
:log_dir => '/var/log/glance',
|
|
:auth_type => 'keystone',
|
|
:enabled => true,
|
|
:manage_service => true,
|
|
:backlog => '4096',
|
|
:workers => '7',
|
|
:auth_host => '127.0.0.1',
|
|
:auth_port => '35357',
|
|
:auth_protocol => 'http',
|
|
:keystone_tenant => 'services',
|
|
:keystone_user => 'glance',
|
|
:keystone_password => 'ChangeMe',
|
|
:database_idle_timeout => '3600',
|
|
:database_connection => 'sqlite:///var/lib/glance/glance.sqlite',
|
|
:show_image_direct_url => false,
|
|
:purge_config => false,
|
|
:known_stores => false,
|
|
:image_cache_dir => '/var/lib/glance/image-cache',
|
|
:os_region_name => 'RegionOne',
|
|
:pipeline => 'keystone',
|
|
}
|
|
end
|
|
|
|
[{:keystone_password => 'ChangeMe'},
|
|
{
|
|
:verbose => true,
|
|
:debug => true,
|
|
:bind_host => '127.0.0.1',
|
|
:bind_port => '9222',
|
|
:registry_host => '127.0.0.1',
|
|
:registry_port => '9111',
|
|
:registry_client_protocol => 'https',
|
|
:auth_type => 'not_keystone',
|
|
:enabled => false,
|
|
:backlog => '4095',
|
|
:workers => '5',
|
|
:auth_host => '127.0.0.2',
|
|
:auth_port => '35358',
|
|
:auth_protocol => 'https',
|
|
:keystone_tenant => 'admin2',
|
|
:keystone_user => 'admin2',
|
|
:keystone_password => 'ChangeMe2',
|
|
:database_idle_timeout => '36002',
|
|
:database_connection => 'mysql:///var:lib@glance/glance',
|
|
:show_image_direct_url => true,
|
|
:image_cache_dir => '/tmp/glance',
|
|
:os_region_name => 'RegionOne2',
|
|
:pipeline => 'keystone2',
|
|
}
|
|
].each do |param_set|
|
|
|
|
describe "when #{param_set == {:keystone_password => 'ChangeMe'} ? "using default" : "specifying"} class parameters" do
|
|
|
|
let :param_hash do
|
|
default_params.merge(param_set)
|
|
end
|
|
|
|
let :params do
|
|
param_set
|
|
end
|
|
|
|
it { is_expected.to contain_class 'glance' }
|
|
it { is_expected.to contain_class 'glance::policy' }
|
|
|
|
it { is_expected.to contain_service('glance-api').with(
|
|
'ensure' => (param_hash[:manage_service] && param_hash[:enabled]) ? 'running': 'stopped',
|
|
'enable' => param_hash[:enabled],
|
|
'hasstatus' => true,
|
|
'hasrestart' => true,
|
|
'tag' => 'glance-service',
|
|
) }
|
|
|
|
it { is_expected.to_not contain_exec('validate_nova_api') }
|
|
it { is_expected.to contain_glance_api_config("paste_deploy/flavor").with_value(param_hash[:pipeline]) }
|
|
|
|
it 'is_expected.to lay down default api config' do
|
|
[
|
|
'verbose',
|
|
'debug',
|
|
'bind_host',
|
|
'bind_port',
|
|
'registry_host',
|
|
'registry_port',
|
|
'registry_client_protocol',
|
|
'show_image_direct_url',
|
|
].each do |config|
|
|
is_expected.to contain_glance_api_config("DEFAULT/#{config}").with_value(param_hash[config.intern])
|
|
end
|
|
end
|
|
|
|
it 'is_expected.to lay down default cache config' do
|
|
[
|
|
'verbose',
|
|
'debug',
|
|
'registry_host',
|
|
'registry_port',
|
|
].each do |config|
|
|
is_expected.to contain_glance_cache_config("DEFAULT/#{config}").with_value(param_hash[config.intern])
|
|
end
|
|
end
|
|
|
|
it 'is_expected.to lay down default glance_store api and cache config' do
|
|
[
|
|
'os_region_name',
|
|
].each do |config|
|
|
is_expected.to contain_glance_cache_config("glance_store/#{config}").with_value(param_hash[config.intern])
|
|
is_expected.to contain_glance_api_config("glance_store/#{config}").with_value(param_hash[config.intern])
|
|
end
|
|
end
|
|
|
|
it 'is_expected.to config db' do
|
|
is_expected.to contain_glance_api_config('database/connection').with_value(param_hash[:database_connection])
|
|
is_expected.to contain_glance_api_config('database/connection').with_value(param_hash[:database_connection]).with_secret(true)
|
|
is_expected.to contain_glance_api_config('database/idle_timeout').with_value(param_hash[:database_idle_timeout])
|
|
end
|
|
|
|
it 'is_expected.to have no ssl options' do
|
|
is_expected.to contain_glance_api_config('DEFAULT/ca_file').with_ensure('absent')
|
|
is_expected.to contain_glance_api_config('DEFAULT/cert_file').with_ensure('absent')
|
|
is_expected.to contain_glance_api_config('DEFAULT/key_file').with_ensure('absent')
|
|
end
|
|
|
|
it 'is_expected.to lay down default auth config' do
|
|
[
|
|
'auth_host',
|
|
'auth_port',
|
|
'auth_protocol'
|
|
].each do |config|
|
|
is_expected.to contain_glance_api_config("keystone_authtoken/#{config}").with_value(param_hash[config.intern])
|
|
end
|
|
end
|
|
it { is_expected.to contain_glance_api_config('keystone_authtoken/auth_admin_prefix').with_ensure('absent') }
|
|
|
|
it 'is_expected.to configure itself for keystone if that is the auth_type' do
|
|
if params[:auth_type] == 'keystone'
|
|
is_expected.to contain('paste_deploy/flavor').with_value('keystone+cachemanagement')
|
|
|
|
['admin_tenant_name', 'admin_user', 'admin_password'].each do |config|
|
|
is_expected.to contain_glance_api_config("keystone_authtoken/#{config}").with_value(param_hash[config.intern])
|
|
end
|
|
is_expected.to contain_glance_api_config('keystone_authtoken/admin_password').with_value(param_hash[:keystone_password]).with_secret(true)
|
|
|
|
['admin_tenant_name', 'admin_user', 'admin_password'].each do |config|
|
|
is_expected.to contain_glance_cache_config("keystone_authtoken/#{config}").with_value(param_hash[config.intern])
|
|
end
|
|
is_expected.to contain_glance_cache_config('keystone_authtoken/admin_password').with_value(param_hash[:keystone_password]).with_secret(true)
|
|
end
|
|
end
|
|
end
|
|
|
|
end
|
|
|
|
describe 'with disabled service managing' do
|
|
let :params do
|
|
{
|
|
:keystone_password => 'ChangeMe',
|
|
:manage_service => false,
|
|
:enabled => false,
|
|
}
|
|
end
|
|
|
|
it { is_expected.to contain_service('glance-api').with(
|
|
'ensure' => nil,
|
|
'enable' => false,
|
|
'hasstatus' => true,
|
|
'hasrestart' => true,
|
|
'tag' => 'glance-service',
|
|
) }
|
|
end
|
|
|
|
describe 'with overridden pipeline' do
|
|
let :params do
|
|
{
|
|
:keystone_password => 'ChangeMe',
|
|
:pipeline => 'something',
|
|
}
|
|
end
|
|
|
|
it { is_expected.to contain_glance_api_config('paste_deploy/flavor').with_value('something') }
|
|
end
|
|
|
|
describe 'with blank pipeline' do
|
|
let :params do
|
|
{
|
|
:keystone_password => 'ChangeMe',
|
|
:pipeline => '',
|
|
}
|
|
end
|
|
|
|
it { is_expected.to contain_glance_api_config('paste_deploy/flavor').with_ensure('absent') }
|
|
end
|
|
|
|
[
|
|
'keystone/',
|
|
'keystone+',
|
|
'+keystone',
|
|
'keystone+cachemanagement+',
|
|
'+'
|
|
].each do |pipeline|
|
|
describe "with pipeline incorrect value #{pipeline}" do
|
|
let :params do
|
|
{
|
|
:keystone_password => 'ChangeMe',
|
|
:pipeline => pipeline
|
|
}
|
|
end
|
|
|
|
it { expect { is_expected.to contain_glance_api_config('filter:paste_deploy/flavor') }.to\
|
|
raise_error(Puppet::Error, /validate_re\(\): .* does not match/) }
|
|
end
|
|
end
|
|
|
|
describe 'with overriden auth_admin_prefix' do
|
|
let :params do
|
|
{
|
|
:keystone_password => 'ChangeMe',
|
|
:auth_admin_prefix => '/keystone/main'
|
|
}
|
|
end
|
|
|
|
it { is_expected.to contain_glance_api_config('keystone_authtoken/auth_admin_prefix').with_value('/keystone/main') }
|
|
end
|
|
|
|
[
|
|
'/keystone/',
|
|
'keystone/',
|
|
'keystone',
|
|
'/keystone/admin/',
|
|
'keystone/admin/',
|
|
'keystone/admin'
|
|
].each do |auth_admin_prefix|
|
|
describe "with auth_admin_prefix_containing incorrect value #{auth_admin_prefix}" do
|
|
let :params do
|
|
{
|
|
:keystone_password => 'ChangeMe',
|
|
:auth_admin_prefix => auth_admin_prefix
|
|
}
|
|
end
|
|
|
|
it { expect { is_expected.to contain_glance_api_config('filter:authtoken/auth_admin_prefix') }.to\
|
|
raise_error(Puppet::Error, /validate_re\(\): "#{auth_admin_prefix}" does not match/) }
|
|
end
|
|
end
|
|
|
|
describe 'with syslog disabled by default' do
|
|
let :params do
|
|
default_params
|
|
end
|
|
|
|
it { is_expected.to contain_glance_api_config('DEFAULT/use_syslog').with_value(false) }
|
|
it { is_expected.to_not contain_glance_api_config('DEFAULT/syslog_log_facility') }
|
|
end
|
|
|
|
describe 'with syslog enabled' do
|
|
let :params do
|
|
default_params.merge({
|
|
:use_syslog => 'true',
|
|
})
|
|
end
|
|
|
|
it { is_expected.to contain_glance_api_config('DEFAULT/use_syslog').with_value(true) }
|
|
it { is_expected.to contain_glance_api_config('DEFAULT/syslog_log_facility').with_value('LOG_USER') }
|
|
end
|
|
|
|
describe 'with syslog enabled and custom settings' do
|
|
let :params do
|
|
default_params.merge({
|
|
:use_syslog => 'true',
|
|
:log_facility => 'LOG_LOCAL0'
|
|
})
|
|
end
|
|
|
|
it { is_expected.to contain_glance_api_config('DEFAULT/use_syslog').with_value(true) }
|
|
it { is_expected.to contain_glance_api_config('DEFAULT/syslog_log_facility').with_value('LOG_LOCAL0') }
|
|
end
|
|
|
|
describe 'with log_file enabled by default' do
|
|
let(:params) { default_params }
|
|
|
|
it { is_expected.to contain_glance_api_config('DEFAULT/log_file').with_value(default_params[:log_file]) }
|
|
|
|
context 'with log_file disabled' do
|
|
let(:params) { default_params.merge!({ :log_file => false }) }
|
|
it { is_expected.to contain_glance_api_config('DEFAULT/log_file').with_ensure('absent') }
|
|
end
|
|
end
|
|
|
|
describe 'with log_dir enabled by default' do
|
|
let(:params) { default_params }
|
|
|
|
it { is_expected.to contain_glance_api_config('DEFAULT/log_dir').with_value(default_params[:log_dir]) }
|
|
|
|
context 'with log_dir disabled' do
|
|
let(:params) { default_params.merge!({ :log_dir => false }) }
|
|
it { is_expected.to contain_glance_api_config('DEFAULT/log_dir').with_ensure('absent') }
|
|
end
|
|
end
|
|
|
|
describe 'with ssl options' do
|
|
let :params do
|
|
default_params.merge({
|
|
:ca_file => '/tmp/ca_file',
|
|
:cert_file => '/tmp/cert_file',
|
|
:key_file => '/tmp/key_file'
|
|
})
|
|
end
|
|
|
|
context 'with ssl options' do
|
|
it { is_expected.to contain_glance_api_config('DEFAULT/ca_file').with_value('/tmp/ca_file') }
|
|
it { is_expected.to contain_glance_api_config('DEFAULT/cert_file').with_value('/tmp/cert_file') }
|
|
it { is_expected.to contain_glance_api_config('DEFAULT/key_file').with_value('/tmp/key_file') }
|
|
end
|
|
end
|
|
describe 'with known_stores by default' do
|
|
let :params do
|
|
default_params
|
|
end
|
|
|
|
it { is_expected.to_not contain_glance_api_config('glance_store/stores').with_value('false') }
|
|
end
|
|
|
|
describe 'with known_stores override' do
|
|
let :params do
|
|
default_params.merge({
|
|
:known_stores => ['glance.store.filesystem.Store','glance.store.http.Store'],
|
|
})
|
|
end
|
|
|
|
it { is_expected.to contain_glance_api_config('glance_store/stores').with_value("glance.store.filesystem.Store,glance.store.http.Store") }
|
|
end
|
|
|
|
describe 'while validating the service with default command' do
|
|
let :params do
|
|
default_params.merge({
|
|
:validate => true,
|
|
})
|
|
end
|
|
it { is_expected.to contain_exec('execute glance-api validation').with(
|
|
:path => '/usr/bin:/bin:/usr/sbin:/sbin',
|
|
:provider => 'shell',
|
|
:tries => '10',
|
|
:try_sleep => '2',
|
|
:command => 'glance --os-auth-url http://localhost:5000/v2.0 --os-tenant-name services --os-username glance --os-password ChangeMe image-list',
|
|
)}
|
|
|
|
it { is_expected.to contain_anchor('create glance-api anchor').with(
|
|
:require => 'Exec[execute glance-api validation]',
|
|
)}
|
|
end
|
|
|
|
describe 'while validating the service with custom command' do
|
|
let :params do
|
|
default_params.merge({
|
|
:validate => true,
|
|
:validation_options => { 'glance-api' => { 'command' => 'my-script' } }
|
|
})
|
|
end
|
|
it { is_expected.to contain_exec('execute glance-api validation').with(
|
|
:path => '/usr/bin:/bin:/usr/sbin:/sbin',
|
|
:provider => 'shell',
|
|
:tries => '10',
|
|
:try_sleep => '2',
|
|
:command => 'my-script',
|
|
)}
|
|
|
|
it { is_expected.to contain_anchor('create glance-api anchor').with(
|
|
:require => 'Exec[execute glance-api validation]',
|
|
)}
|
|
end
|
|
|
|
describe 'with identity and auth settings' do
|
|
let :params do
|
|
{
|
|
:keystone_password => 'ChangeMe',
|
|
}
|
|
end
|
|
context 'with custom keystone identity_uri' do
|
|
let :params do
|
|
default_params.merge!({
|
|
:identity_uri => 'https://foo.bar:1234/',
|
|
})
|
|
end
|
|
it 'configures identity_uri' do
|
|
is_expected.to contain_glance_api_config('keystone_authtoken/identity_uri').with_value("https://foo.bar:1234/");
|
|
# since only identity_uri is set the deprecated auth parameters is_expected.to
|
|
# still get set in case they are still in use
|
|
is_expected.to contain_glance_api_config('keystone_authtoken/auth_host').with_value('127.0.0.1');
|
|
is_expected.to contain_glance_api_config('keystone_authtoken/auth_port').with_value('35357');
|
|
is_expected.to contain_glance_api_config('keystone_authtoken/auth_protocol').with_value('http');
|
|
end
|
|
end
|
|
|
|
context 'with custom keystone identity_uri and auth_uri' do
|
|
let :params do
|
|
default_params.merge!({
|
|
:identity_uri => 'https://foo.bar:35357/',
|
|
:auth_uri => 'https://foo.bar:5000/v2.0/',
|
|
})
|
|
end
|
|
it 'configures identity_uri' do
|
|
is_expected.to contain_glance_api_config('keystone_authtoken/identity_uri').with_value("https://foo.bar:35357/");
|
|
is_expected.to contain_glance_api_config('keystone_authtoken/auth_uri').with_value("https://foo.bar:5000/v2.0/");
|
|
is_expected.to contain_glance_api_config('keystone_authtoken/auth_host').with_ensure('absent')
|
|
is_expected.to contain_glance_api_config('keystone_authtoken/auth_port').with_ensure('absent')
|
|
is_expected.to contain_glance_api_config('keystone_authtoken/auth_protocol').with_ensure('absent')
|
|
is_expected.to contain_glance_api_config('keystone_authtoken/auth_admin_prefix').with_ensure('absent')
|
|
end
|
|
end
|
|
end
|
|
|
|
|
|
describe 'on Debian platforms' do
|
|
let :facts do
|
|
{ :osfamily => 'Debian' }
|
|
end
|
|
let(:params) { default_params }
|
|
|
|
# We only test this on Debian platforms, since on RedHat there isn't a
|
|
# separate package for glance API.
|
|
['present', 'latest'].each do |package_ensure|
|
|
context "with package_ensure '#{package_ensure}'" do
|
|
let(:params) { default_params.merge({ :package_ensure => package_ensure }) }
|
|
it { is_expected.to contain_package('glance-api').with(
|
|
:ensure => package_ensure,
|
|
:tag => ['openstack', 'glance-package']
|
|
)}
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'on RedHat platforms' do
|
|
let :facts do
|
|
{ :osfamily => 'RedHat' }
|
|
end
|
|
let(:params) { default_params }
|
|
|
|
it { is_expected.to contain_package('openstack-glance').with(
|
|
:tag => ['openstack', 'glance-package'],
|
|
)}
|
|
end
|
|
|
|
describe 'on unknown platforms' do
|
|
let :facts do
|
|
{ :osfamily => 'unknown' }
|
|
end
|
|
let(:params) { default_params }
|
|
|
|
it_raises 'a Puppet::Error', /module glance only support osfamily RedHat and Debian/
|
|
end
|
|
|
|
end
|