Refactor rspec tests
Change-Id: I4721cacff86a88ff360b7a3ede45464ff44e684d
This commit is contained in:
parent
7213ea5388
commit
700c637c9f
@ -1,10 +1,10 @@
|
||||
require 'spec_helper'
|
||||
|
||||
describe 'horizon' do
|
||||
|
||||
let :params do
|
||||
{ 'secret_key' => 'elj1IWiLoWHgcyYxFVLj7cM5rGOOxWl0',
|
||||
'fqdn' => '*'
|
||||
}
|
||||
'fqdn' => '*' }
|
||||
end
|
||||
|
||||
let :pre_condition do
|
||||
@ -19,24 +19,71 @@ describe 'horizon' do
|
||||
{ :concat_basedir => '/var/lib/puppet/concat' }
|
||||
end
|
||||
|
||||
describe 'on RedHat platforms' do
|
||||
shared_examples 'horizon' do
|
||||
|
||||
it { should contain_service('httpd').with_name(platforms_params[:http_service]) }
|
||||
it { should contain_file(platforms_params[:httpd_config_file]) }
|
||||
|
||||
it {
|
||||
should contain_file_line('horizon_redirect_rule').with(
|
||||
:line => "RedirectMatch permanent ^/$ #{platforms_params[:root_url]}/")
|
||||
}
|
||||
|
||||
context 'with default parameters' do
|
||||
|
||||
it 'installs horizon package' do
|
||||
should contain_package('horizon').with_ensure('present')
|
||||
end
|
||||
|
||||
it 'generates local_settings.py' do
|
||||
verify_contents(subject, platforms_params[:config_file], [
|
||||
'DEBUG = False',
|
||||
"ALLOWED_HOSTS = ['*', ]",
|
||||
"SECRET_KEY = 'elj1IWiLoWHgcyYxFVLj7cM5rGOOxWl0'",
|
||||
'OPENSTACK_KEYSTONE_URL = "http://127.0.0.1:5000/v2.0"',
|
||||
'OPENSTACK_KEYSTONE_DEFAULT_ROLE = "_member_"',
|
||||
" 'can_set_mount_point': True,",
|
||||
'API_RESULT_LIMIT = 1000',
|
||||
"LOGIN_URL = '#{platforms_params[:root_url]}/auth/login/'",
|
||||
"LOGOUT_URL = '#{platforms_params[:root_url]}/auth/logout/'",
|
||||
"LOGIN_REDIRECT_URL = '#{platforms_params[:root_url]}'",
|
||||
'COMPRESS_OFFLINE = True'
|
||||
])
|
||||
end
|
||||
end
|
||||
|
||||
context 'with overridden parameters' do
|
||||
before do
|
||||
facts.merge!({
|
||||
:osfamily => 'RedHat',
|
||||
:operatingsystemrelease => '6.0'
|
||||
params.merge!({
|
||||
:cache_server_ip => '10.0.0.1',
|
||||
:keystone_default_role => 'SwiftOperator',
|
||||
:keystone_url => 'https://keystone.example.com:4682',
|
||||
:openstack_endpoint_type => 'internalURL',
|
||||
:secondary_endpoint_type => 'ANY-VALUE',
|
||||
:django_debug => true,
|
||||
:api_result_limit => 4682,
|
||||
:can_set_mount_point => false,
|
||||
:compress_offline => 'False',
|
||||
})
|
||||
end
|
||||
|
||||
it { should contain_service('httpd').with_name('httpd') }
|
||||
it { should contain_file('/etc/httpd/conf.d/openstack-dashboard.conf') }
|
||||
describe 'with default parameters' do
|
||||
it { should contain_package('horizon').with_ensure('present') }
|
||||
it { should contain_file_line('horizon_redirect_rule').with(
|
||||
:line => "RedirectMatch permanent ^/$ \/dashboard/"
|
||||
)}
|
||||
it 'generates local_settings.py' do
|
||||
verify_contents(subject, platforms_params[:config_file], [
|
||||
'DEBUG = True',
|
||||
"ALLOWED_HOSTS = ['*', ]",
|
||||
"SECRET_KEY = 'elj1IWiLoWHgcyYxFVLj7cM5rGOOxWl0'",
|
||||
'OPENSTACK_KEYSTONE_URL = "https://keystone.example.com:4682"',
|
||||
'OPENSTACK_KEYSTONE_DEFAULT_ROLE = "SwiftOperator"',
|
||||
" 'can_set_mount_point': False,",
|
||||
'OPENSTACK_ENDPOINT_TYPE = "internalURL"',
|
||||
'SECONDARY_ENDPOINT_TYPE = "ANY-VALUE"',
|
||||
'API_RESULT_LIMIT = 4682',
|
||||
'COMPRESS_OFFLINE = False'
|
||||
])
|
||||
end
|
||||
end
|
||||
|
||||
describe 'when ssl is enabled' do
|
||||
context 'with ssl enabled' do
|
||||
before do
|
||||
params.merge!({
|
||||
:listen_ssl => true,
|
||||
@ -49,78 +96,13 @@ describe 'horizon' do
|
||||
it { should contain_file_line('httpd_sslcert_path').with(
|
||||
:line => "SSLCertificateFile /etc/pki/tls/certs/httpd.crt"
|
||||
)}
|
||||
|
||||
it { should contain_file_line('httpd_sslkey_path').with(
|
||||
:line => "SSLCertificateKeyFile /etc/pki/tls/private/httpd.key"
|
||||
)}
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
describe 'on Debian platforms' do
|
||||
before do
|
||||
facts.merge!({
|
||||
:osfamily => 'Debian',
|
||||
:operatingsystemrelease => '6.0'
|
||||
})
|
||||
end
|
||||
|
||||
it { should contain_service('httpd').with_name('apache2') }
|
||||
it { should_not contain_file('/etc/httpd/conf.d/openstack-dashboard.conf') }
|
||||
|
||||
describe 'with default parameters' do
|
||||
it { should contain_package('horizon').with_ensure('present') }
|
||||
it { should contain_file_line('horizon_redirect_rule').with(
|
||||
:line => "RedirectMatch permanent ^/$ /horizon/"
|
||||
)}
|
||||
it 'generates local_settings.py' do
|
||||
verify_contents(subject, '/etc/openstack-dashboard/local_settings.py', [
|
||||
'DEBUG = False',
|
||||
"ALLOWED_HOSTS = ['*', ]",
|
||||
"SECRET_KEY = 'elj1IWiLoWHgcyYxFVLj7cM5rGOOxWl0'",
|
||||
'OPENSTACK_KEYSTONE_URL = "http://127.0.0.1:5000/v2.0"',
|
||||
'OPENSTACK_KEYSTONE_DEFAULT_ROLE = "_member_"',
|
||||
" 'can_set_mount_point': True,",
|
||||
'API_RESULT_LIMIT = 1000',
|
||||
"LOGIN_URL = '/horizon/auth/login/'",
|
||||
"LOGOUT_URL = '/horizon/auth/logout/'",
|
||||
"LOGIN_REDIRECT_URL = '/horizon'",
|
||||
'COMPRESS_OFFLINE = True'
|
||||
])
|
||||
end
|
||||
end
|
||||
|
||||
describe 'when overriding parameters' do
|
||||
before do
|
||||
params.merge!({
|
||||
:cache_server_ip => '10.0.0.1',
|
||||
:keystone_host => 'keystone.example.com',
|
||||
:keystone_port => 4682,
|
||||
:keystone_scheme => 'https',
|
||||
:keystone_default_role => 'SwiftOperator',
|
||||
:keystone_url => false,
|
||||
:django_debug => true,
|
||||
:api_result_limit => 4682,
|
||||
:can_set_mount_point => false,
|
||||
:compress_offline => 'False',
|
||||
})
|
||||
end
|
||||
|
||||
it 'generates local_settings.py' do
|
||||
verify_contents(subject, '/etc/openstack-dashboard/local_settings.py', [
|
||||
'DEBUG = True',
|
||||
"ALLOWED_HOSTS = ['*', ]",
|
||||
"SECRET_KEY = 'elj1IWiLoWHgcyYxFVLj7cM5rGOOxWl0'",
|
||||
'OPENSTACK_HOST = "keystone.example.com"',
|
||||
'OPENSTACK_KEYSTONE_URL = "https://%s:4682/v2.0" % OPENSTACK_HOST',
|
||||
'OPENSTACK_KEYSTONE_DEFAULT_ROLE = "SwiftOperator"',
|
||||
" 'can_set_mount_point': False,",
|
||||
'API_RESULT_LIMIT = 4682',
|
||||
'COMPRESS_OFFLINE = False'
|
||||
])
|
||||
end
|
||||
end
|
||||
|
||||
describe 'with overriding local_settings_template' do
|
||||
context 'with overriding local_settings_template' do
|
||||
before do
|
||||
params.merge!({
|
||||
:django_debug => 'True',
|
||||
@ -130,7 +112,7 @@ describe 'horizon' do
|
||||
end
|
||||
|
||||
it 'uses the custom local_settings.py template' do
|
||||
verify_contents(subject, '/etc/openstack-dashboard/local_settings.py', [
|
||||
verify_contents(subject, platforms_params[:config_file], [
|
||||
'# Custom local_settings.py',
|
||||
'DEBUG = True',
|
||||
"HORIZON_CONFIG = {",
|
||||
@ -151,74 +133,43 @@ describe 'horizon' do
|
||||
])
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
describe 'when overriding keystone_url' do
|
||||
context 'on RedHat platforms' do
|
||||
before do
|
||||
params.merge!({
|
||||
:keystone_url => 'https://identity.example.com/public/endpoint/v2.0'
|
||||
facts.merge!({
|
||||
:osfamily => 'RedHat',
|
||||
:operatingsystemrelease => '6.0'
|
||||
})
|
||||
end
|
||||
|
||||
it 'generates local_settings.py' do
|
||||
verify_contents(subject, '/etc/openstack-dashboard/local_settings.py', [
|
||||
'DEBUG = False',
|
||||
"ALLOWED_HOSTS = ['*', ]",
|
||||
"SECRET_KEY = 'elj1IWiLoWHgcyYxFVLj7cM5rGOOxWl0'",
|
||||
'OPENSTACK_KEYSTONE_URL = "https://identity.example.com/public/endpoint/v2.0"',
|
||||
'OPENSTACK_KEYSTONE_DEFAULT_ROLE = "_member_"',
|
||||
" 'can_set_mount_point': True,",
|
||||
'API_RESULT_LIMIT = 1000',
|
||||
"LOGIN_URL = '/horizon/auth/login/'",
|
||||
"LOGOUT_URL = '/horizon/auth/logout/'",
|
||||
"LOGIN_REDIRECT_URL = '/horizon'"
|
||||
])
|
||||
end
|
||||
let :platforms_params do
|
||||
{ :config_file => '/etc/openstack-dashboard/local_settings',
|
||||
:http_service => 'httpd',
|
||||
:httpd_config_file => '/etc/httpd/conf.d/openstack-dashboard.conf',
|
||||
:package_name => 'openstack-dashboard',
|
||||
:root_url => '/dashboard' }
|
||||
end
|
||||
|
||||
describe 'when ssl is enabled' do
|
||||
it_behaves_like 'horizon'
|
||||
end
|
||||
|
||||
context 'on Debian platforms' do
|
||||
before do
|
||||
params.merge!({
|
||||
:listen_ssl => true,
|
||||
:horizon_cert => '/etc/ssl/localcerts/apache.crt',
|
||||
:horizon_key => '/etc/ssl/localcerts/apache.key',
|
||||
:horizon_ca => '/etc/ssl/localcerts/ca.crt',
|
||||
facts.merge!({
|
||||
:osfamily => 'Debian',
|
||||
:operatingsystemrelease => '6.0'
|
||||
})
|
||||
end
|
||||
|
||||
it { should contain_file_line('httpd_sslcert_path').with(
|
||||
:line => "SSLCertificateFile /etc/ssl/localcerts/apache.crt"
|
||||
)}
|
||||
it { should contain_file_line('httpd_sslkey_path').with(
|
||||
:line => "SSLCertificateKeyFile /etc/ssl/localcerts/apache.key"
|
||||
)}
|
||||
let :platforms_params do
|
||||
{ :config_file => '/etc/openstack-dashboard/local_settings.py',
|
||||
:http_service => 'apache2',
|
||||
:httpd_config_file => '/etc/apache2/conf.d/openstack-dashboard.conf',
|
||||
:package_name => 'openstack-dashboard-apache',
|
||||
:root_url => '/horizon' }
|
||||
end
|
||||
|
||||
describe 'with openstack_endpoint_type' do
|
||||
before do
|
||||
params.merge!({
|
||||
:openstack_endpoint_type => 'internalURL',
|
||||
})
|
||||
end
|
||||
|
||||
it 'generates local_settings.py' do
|
||||
verify_contents(subject, '/etc/openstack-dashboard/local_settings.py', [
|
||||
'OPENSTACK_ENDPOINT_TYPE = "internalURL"',
|
||||
])
|
||||
end
|
||||
end
|
||||
|
||||
describe 'with secondary_endpoint_type' do
|
||||
before do
|
||||
params.merge!({
|
||||
:secondary_endpoint_type => 'ANY-VALUE',
|
||||
})
|
||||
end
|
||||
|
||||
it 'generates local_settings.py' do
|
||||
verify_contents(subject, '/etc/openstack-dashboard/local_settings.py', [
|
||||
'SECONDARY_ENDPOINT_TYPE = "ANY-VALUE"',
|
||||
])
|
||||
end
|
||||
end
|
||||
it_behaves_like 'horizon'
|
||||
end
|
||||
end
|
||||
|
4
spec/fixtures/override_local_settings.py.erb
vendored
4
spec/fixtures/override_local_settings.py.erb
vendored
@ -1,5 +1,5 @@
|
||||
# Custom local_settings.py
|
||||
DEBUG = <%= django_debug %>
|
||||
DEBUG = <%= @django_debug %>
|
||||
|
||||
HORIZON_CONFIG = {
|
||||
'dashboards': ('project', 'admin', 'settings',),
|
||||
@ -11,7 +11,7 @@ HORIZON_CONFIG = {
|
||||
'fade_duration': 1500,
|
||||
'types': ['alert-success', 'alert-info']
|
||||
},
|
||||
'help_url': "<%= help_url %>",
|
||||
'help_url': "<%= @help_url %>",
|
||||
'exceptions': {'recoverable': exceptions.RECOVERABLE,
|
||||
'not_found': exceptions.NOT_FOUND,
|
||||
'unauthorized': exceptions.UNAUTHORIZED},
|
||||
|
Loading…
Reference in New Issue
Block a user