2011-12-19 16:25:35 +01:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe 'mysql::db', :type => :define do
|
2013-09-13 19:13:59 +02:00
|
|
|
let(:facts) {{ :osfamily => 'RedHat' }}
|
2011-12-19 16:25:35 +01:00
|
|
|
let(:title) { 'test_db' }
|
2011-12-20 05:46:29 +01:00
|
|
|
|
2011-12-19 16:25:35 +01:00
|
|
|
let(:params) {
|
2011-12-20 05:46:29 +01:00
|
|
|
{ 'user' => 'testuser',
|
|
|
|
'password' => 'testpass',
|
2011-12-19 16:25:35 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-08-22 00:40:42 +02:00
|
|
|
it 'should report an error when ensure is not present or absent' do
|
|
|
|
params.merge!({'ensure' => 'invalid_val'})
|
2013-09-13 19:13:59 +02:00
|
|
|
expect { subject }.to raise_error(Puppet::Error,
|
2012-08-22 00:40:42 +02:00
|
|
|
/invalid_val is not supported for ensure\. Allowed values are 'present' and 'absent'\./)
|
|
|
|
end
|
|
|
|
|
2011-12-20 05:46:29 +01:00
|
|
|
it 'should not notify the import sql exec if no sql script was provided' do
|
2013-08-18 02:54:02 +02:00
|
|
|
should contain_mysql_database('test_db').without_notify
|
2011-12-20 05:46:29 +01:00
|
|
|
end
|
|
|
|
|
2012-02-09 20:26:00 +01:00
|
|
|
it 'should subscribe to database if sql script is given' do
|
2011-12-20 05:46:29 +01:00
|
|
|
params.merge!({'sql' => 'test_sql'})
|
2013-08-18 02:54:02 +02:00
|
|
|
should contain_exec('test_db-import').with_subscribe('Mysql_database[test_db]')
|
2011-12-20 05:46:29 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'should only import sql script on creation if not enforcing' do
|
|
|
|
params.merge!({'sql' => 'test_sql', 'enforce_sql' => false})
|
2012-02-09 20:26:00 +01:00
|
|
|
should contain_exec('test_db-import').with_refreshonly(true)
|
2011-12-20 05:46:29 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'should import sql script on creation if enforcing' do
|
|
|
|
params.merge!({'sql' => 'test_sql', 'enforce_sql' => true})
|
2012-02-09 20:26:00 +01:00
|
|
|
should contain_exec('test_db-import').with_refreshonly(false)
|
2011-12-19 16:25:35 +01:00
|
|
|
end
|
2013-08-18 02:54:02 +02:00
|
|
|
|
2012-08-22 00:40:42 +02:00
|
|
|
it 'should not create database and database user' do
|
|
|
|
params.merge!({'ensure' => 'absent', 'host' => 'localhost'})
|
2013-08-18 02:54:02 +02:00
|
|
|
should contain_mysql_database('test_db').with_ensure('absent')
|
|
|
|
should contain_mysql_user('testuser@localhost').with_ensure('absent')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'should create with an appropriate collate and charset' do
|
|
|
|
params.merge!({'charset' => 'utf8', 'collate' => 'utf8_danish_ci'})
|
|
|
|
should contain_mysql_database('test_db').with({
|
|
|
|
'charset' => 'utf8',
|
|
|
|
'collate' => 'utf8_danish_ci',
|
|
|
|
})
|
2012-08-22 00:40:42 +02:00
|
|
|
end
|
2011-12-19 16:25:35 +01:00
|
|
|
end
|