115 lines
3.4 KiB
Ruby
115 lines
3.4 KiB
Ruby
# encoding: UTF-8
|
|
require_relative 'spec_helper'
|
|
|
|
describe 'openstack-dashboard::server' do
|
|
|
|
describe 'redhat' do
|
|
|
|
let(:runner) { ChefSpec::Runner.new(REDHAT_OPTS) }
|
|
let(:node) { runner.node }
|
|
let(:chef_run) do
|
|
runner.converge(described_recipe)
|
|
end
|
|
|
|
include_context 'dashboard_stubs'
|
|
include_context 'redhat_stubs'
|
|
|
|
it 'executes set-selinux-permissive' do
|
|
cmd = '/sbin/setenforce Permissive'
|
|
|
|
expect(chef_run).to run_execute(cmd)
|
|
end
|
|
|
|
it 'installs packages' do
|
|
expect(chef_run).to upgrade_package('openstack-dashboard')
|
|
expect(chef_run).to upgrade_package('MySQL-python')
|
|
end
|
|
|
|
it 'installs db2 python packages if explicitly told' do
|
|
node.set['openstack']['db']['dashboard']['service_type'] = 'db2'
|
|
%w{python-ibm-db python-ibm-db-django python-ibm-db-sa}.each do |pkg|
|
|
expect(chef_run).to upgrade_package(pkg)
|
|
end
|
|
end
|
|
|
|
it 'executes set-selinux-enforcing' do
|
|
cmd = '/sbin/setenforce Enforcing ; restorecon -R /etc/httpd'
|
|
|
|
expect(chef_run).to run_execute(cmd)
|
|
end
|
|
|
|
describe 'local_settings' do
|
|
let(:file) { chef_run.template('/etc/openstack-dashboard/local_settings') }
|
|
|
|
it 'has proper owner' do
|
|
expect(file.owner).to eq('root')
|
|
expect(file.group).to eq('root')
|
|
end
|
|
|
|
it 'has proper modes' do
|
|
expect(sprintf('%o', file.mode)).to eq('644')
|
|
end
|
|
|
|
it 'has urls set' do
|
|
[
|
|
%r(^LOGIN_URL = '/auth/login/'$),
|
|
%r(^LOGOUT_URL = '/auth/logout/'$),
|
|
/^LOGIN_REDIRECT_URL = '\/'$/
|
|
].each do |line|
|
|
expect(chef_run).to render_file(file.name).with_content(line)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'certs' do
|
|
let(:crt) { chef_run.cookbook_file('/etc/pki/tls/certs/horizon.pem') }
|
|
let(:key) { chef_run.cookbook_file('/etc/pki/tls/private/horizon.key') }
|
|
|
|
it 'has proper owner' do
|
|
[crt, key].each do |file|
|
|
expect(file.owner).to eq('root')
|
|
expect(file.group).to eq('root')
|
|
end
|
|
end
|
|
|
|
it 'has proper modes' do
|
|
expect(sprintf('%o', crt.mode)).to eq('644')
|
|
expect(sprintf('%o', key.mode)).to eq('640')
|
|
end
|
|
|
|
it 'notifies restore-selinux-context' do
|
|
expect(crt).to notify('execute[restore-selinux-context]').to(:run)
|
|
expect(key).to notify('execute[restore-selinux-context]').to(:run)
|
|
end
|
|
end
|
|
|
|
it 'deletes openstack-dashboard.conf' do
|
|
file = '/etc/httpd/conf.d/openstack-dashboard.conf'
|
|
|
|
expect(chef_run).to delete_file(file)
|
|
end
|
|
|
|
it 'does not remove openstack-dashboard-ubuntu-theme package' do
|
|
|
|
expect(chef_run).not_to purge_package('openstack-dashboard-ubuntu-theme')
|
|
end
|
|
|
|
it 'does not execute restore-selinux-context' do
|
|
cmd = 'restorecon -Rv /etc/httpd /etc/pki; chcon -R -t httpd_sys_content_t /usr/share/openstack-dashboard || :'
|
|
|
|
expect(chef_run).not_to run_execute(cmd)
|
|
end
|
|
|
|
it 'sets the WSGI daemon user to attribute default' do
|
|
file = chef_run.template('/etc/httpd/sites-available/openstack-dashboard')
|
|
expect(chef_run).to render_file(file.name).with_content('WSGIDaemonProcess dashboard user=apache')
|
|
end
|
|
|
|
it 'has correct ownership on file with attribute defaults' do
|
|
file = chef_run.file('/usr/share/openstack-dashboard/openstack_dashboard/local/.secret_key_store')
|
|
expect(file.owner).to eq('apache')
|
|
expect(file.group).to eq('apache')
|
|
end
|
|
end
|
|
end
|