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