require File.expand_path(File.join(File.dirname(__FILE__),'../spec_helper')) describe 'apache::vhost::php::drupal', :type => 'define' do let(:title){ 'example.com' } let(:facts){ { :fqdn => 'apache.example.com', :operatingsystem => 'CentOS', :operatingsystemmajrelease => '7', } } describe 'with standard' do it { should contain_file('/etc/cron.d/drupal_cron_example.com').with( :content => "0 * * * * apache wget -O - -q -t 1 http://example.com/cron.php\n", :owner => 'root', :group => 0, :mode => '0644', )} # only test the differences from the default it { should contain_apache__vhost__php__webapp('example.com').with( :manage_directories => false, :template_partial => 'apache/vhosts/php_drupal/partial.erb', :manage_config => false, :php_settings => { 'magic_quotes_gpc' => 0, 'register_globals' => 0, 'session.auto_start' => 0, 'mbstring.http_input' => 'pass', 'mbstring.http_output' => 'pass', 'mbstring.encoding_translation' => 0, } )} # go deeper in the catalog and test the produced template it { should contain_apache__vhost__file('example.com').with_content( " Include include.d/defaults.inc ServerName example.com DocumentRoot /var/www/vhosts/example.com/www/ DirectoryIndex index.htm index.html index.php ErrorLog /var/www/vhosts/example.com/logs/error_log CustomLog /var/www/vhosts/example.com/logs/access_log combined AllowOverride None php_admin_flag engine on php_admin_value error_log /var/www/vhosts/example.com/logs/php_error_log php_admin_value magic_quotes_gpc 0 php_admin_value mbstring.encoding_translation 0 php_admin_value mbstring.http_input pass php_admin_value mbstring.http_output pass php_admin_value open_basedir /var/www/vhosts/example.com/www:/var/www/vhosts/example.com/data:/var/www/upload_tmp_dir/example.com:/var/www/session.save_path/example.com php_admin_value register_globals 0 php_admin_flag safe_mode on php_admin_value session.auto_start 0 php_admin_value session.save_path /var/www/session.save_path/example.com php_admin_value upload_tmp_dir /var/www/upload_tmp_dir/example.com # Protect files and directories from prying eyes. Order allow,deny # Customized error messages. ErrorDocument 404 /index.php RewriteEngine on RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule ^(.*)$ index.php?q=$1 [L,QSA] SetHandler Drupal_Security_Do_Not_Remove_See_SA_2006_006 Options None Options +FollowSymLinks SecRuleEngine On SecAuditEngine RelevantOnly SecAuditLogType Concurrent SecAuditLogStorageDir /var/www/vhosts/example.com/logs/ SecAuditLog /var/www/vhosts/example.com/logs/mod_security_audit.log SecDebugLog /var/www/vhosts/example.com/logs/mod_security_debug.log " )} end describe 'with mod_fcgid' do let(:params){ { :run_mode => 'fcgid', :run_uid => 'foo', :run_gid => 'bar', } } it { should contain_file('/etc/cron.d/drupal_cron_example.com').with( :content => "0 * * * * apache wget -O - -q -t 1 http://example.com/cron.php\n", :owner => 'root', :group => 0, :mode => '0644', )} # only test variables that are tuned it { should contain_apache__vhost__php__webapp('example.com').with( :run_mode => 'fcgid', :run_uid => 'foo', :run_gid => 'bar', :manage_directories => false, :template_partial => 'apache/vhosts/php_drupal/partial.erb', :manage_config => false, :php_settings => { 'magic_quotes_gpc' => 0, 'register_globals' => 0, 'session.auto_start' => 0, 'mbstring.http_input' => 'pass', 'mbstring.http_output' => 'pass', 'mbstring.encoding_translation' => 0, }, )} # go deeper in the catalog and test the produced template it { should contain_apache__vhost__file('example.com').with_content( " Include include.d/defaults.inc ServerName example.com DocumentRoot /var/www/vhosts/example.com/www/ DirectoryIndex index.htm index.html index.php ErrorLog /var/www/vhosts/example.com/logs/error_log CustomLog /var/www/vhosts/example.com/logs/access_log combined SuexecUserGroup foo bar FcgidMaxRequestsPerProcess 5000 FCGIWrapper /var/www/mod_fcgid-starters/example.com/example.com-starter .php AddHandler fcgid-script .php AllowOverride None Options +ExecCGI # Protect files and directories from prying eyes. Order allow,deny # Customized error messages. ErrorDocument 404 /index.php RewriteEngine on RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule ^(.*)$ index.php?q=$1 [L,QSA] SetHandler Drupal_Security_Do_Not_Remove_See_SA_2006_006 Options None Options +FollowSymLinks SecRuleEngine On SecAuditEngine RelevantOnly SecAuditLogType Concurrent SecAuditLogStorageDir /var/www/vhosts/example.com/logs/ SecAuditLog /var/www/vhosts/example.com/logs/mod_security_audit.log SecDebugLog /var/www/vhosts/example.com/logs/mod_security_debug.log " )} end end