|
require 'spec_helper'
|
|
|
|
|
|
describe 'foreman::config::passenger' do
|
|
let :facts do {
|
|
:concat_basedir => '/nonexistant',
|
|
:fqdn => 'foreman.example.org',
|
|
:operatingsystem => 'RedHat',
|
|
:operatingsystemrelease => '6.4',
|
|
:osfamily => 'RedHat',
|
|
} end
|
|
|
|
describe 'with minimal parameters' do
|
|
let :params do {
|
|
:app_root => '/usr/share/foreman',
|
|
:ssl => false,
|
|
:user => 'foreman',
|
|
} end
|
|
|
|
it 'should include apache with modules' do
|
|
should contain_class('apache')
|
|
should contain_class('apache::mod::headers')
|
|
should contain_class('apache::mod::passenger')
|
|
end
|
|
|
|
it 'should ensure ownership' do
|
|
should contain_file("#{params[:app_root]}/config.ru").with_owner(params[:user])
|
|
should contain_file("#{params[:app_root]}/config/environment.rb").with_owner(params[:user])
|
|
end
|
|
end
|
|
|
|
describe 'with vhost and ssl' do
|
|
let :params do {
|
|
:app_root => '/usr/share/foreman',
|
|
:use_vhost => true,
|
|
:ssl => true,
|
|
:ssl_cert => 'cert.pem',
|
|
:ssl_key => 'key.pem',
|
|
:ssl_ca => 'ca.pem',
|
|
} end
|
|
|
|
it 'should contain the docroot' do
|
|
should contain_file("#{params[:app_root]}/public")
|
|
end
|
|
|
|
it 'should include a http vhost' do
|
|
should contain_apache__vhost('foreman').with({
|
|
:ip => nil,
|
|
:servername => facts[:fqdn],
|
|
:serveraliases => ['foreman'],
|
|
:docroot => "#{params[:app_root]}/public",
|
|
:priority => '5',
|
|
:options => ['none'],
|
|
:port => 80,
|
|
:custom_fragment => %r{^<Directory #{params[:app_root]}/public>$},
|
|
})
|
|
end
|
|
|
|
it 'should include a https vhost' do
|
|
should contain_apache__vhost('foreman-ssl').with({
|
|
:ip => nil,
|
|
:servername => facts[:fqdn],
|
|
:serveraliases => ['foreman'],
|
|
:docroot => "#{params[:app_root]}/public",
|
|
:priority => '5',
|
|
:options => ['none'],
|
|
:port => 443,
|
|
:ssl => true,
|
|
:ssl_cert => params[:ssl_cert],
|
|
:ssl_key => params[:ssl_key],
|
|
:ssl_chain => params[:ssl_ca],
|
|
:ssl_ca => params[:ssl_ca],
|
|
:ssl_verify_client => 'optional',
|
|
:ssl_options => '+StdEnvVars',
|
|
:ssl_verify_depth => '3',
|
|
:custom_fragment => %r{^<Directory #{params[:app_root]}/public>$},
|
|
})
|
|
end
|
|
end
|
|
end
|