2014-08-14 20:55:20 +02:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe 'mysql::server' do
|
|
|
|
context 'my.cnf template' do
|
2015-10-13 12:29:42 +02:00
|
|
|
on_supported_os.each do |os, facts|
|
|
|
|
context "on #{os}" do
|
|
|
|
let(:facts) {
|
|
|
|
facts.merge({
|
|
|
|
:root_home => '/root',
|
|
|
|
})
|
|
|
|
}
|
2014-08-14 20:55:20 +02:00
|
|
|
|
2015-10-13 12:29:42 +02:00
|
|
|
context 'normal entry' do
|
|
|
|
let(:params) {{ :override_options => { 'mysqld' => { 'socket' => '/var/lib/mysql/mysql.sock' } } }}
|
|
|
|
it do
|
|
|
|
is_expected.to contain_file('mysql-config-file').with({
|
|
|
|
:mode => '0644',
|
|
|
|
:selinux_ignore_defaults => true,
|
|
|
|
}).with_content(/socket = \/var\/lib\/mysql\/mysql.sock/)
|
2014-08-14 20:55:20 +02:00
|
|
|
end
|
2015-10-13 12:29:42 +02:00
|
|
|
end
|
2014-08-14 20:55:20 +02:00
|
|
|
|
2015-10-13 12:29:42 +02:00
|
|
|
describe 'array entry' do
|
|
|
|
let(:params) {{ :override_options => { 'mysqld' => { 'replicate-do-db' => ['base1', 'base2'], } }}}
|
|
|
|
it do
|
|
|
|
is_expected.to contain_file('mysql-config-file').with_content(
|
|
|
|
/.*replicate-do-db = base1\nreplicate-do-db = base2.*/
|
|
|
|
)
|
2014-08-14 20:55:20 +02:00
|
|
|
end
|
2015-10-13 12:29:42 +02:00
|
|
|
end
|
2014-08-14 20:55:20 +02:00
|
|
|
|
2015-10-13 12:29:42 +02:00
|
|
|
describe 'ssl set to true' do
|
|
|
|
let(:params) {{ :override_options => { 'mysqld' => { 'ssl' => true }}}}
|
|
|
|
it { is_expected.to contain_file('mysql-config-file').with_content(/ssl/) }
|
|
|
|
it { is_expected.to contain_file('mysql-config-file').without_content(/ssl = true/) }
|
|
|
|
end
|
2014-08-14 20:55:20 +02:00
|
|
|
|
2015-10-13 12:29:42 +02:00
|
|
|
describe 'ssl set to false' do
|
|
|
|
let(:params) {{ :override_options => { 'mysqld' => { 'ssl' => false }}}}
|
|
|
|
it { is_expected.to contain_file('mysql-config-file').with_content(/ssl = false/) }
|
|
|
|
end
|
2014-08-14 20:55:20 +02:00
|
|
|
|
2015-10-13 12:29:42 +02:00
|
|
|
# ssl-disable (and ssl) are special cased within mysql.
|
|
|
|
describe 'possibility of disabling ssl completely' do
|
|
|
|
let(:params) {{ :override_options => { 'mysqld' => { 'ssl' => true, 'ssl-disable' => true }}}}
|
|
|
|
it { is_expected.to contain_file('mysql-config-file').without_content(/ssl = true/) }
|
|
|
|
end
|
2014-08-14 20:55:20 +02:00
|
|
|
|
2015-10-13 12:29:42 +02:00
|
|
|
describe 'a non ssl option set to true' do
|
|
|
|
let(:params) {{ :override_options => { 'mysqld' => { 'test' => true }}}}
|
|
|
|
it { is_expected.to contain_file('mysql-config-file').with_content(/^test$/) }
|
|
|
|
it { is_expected.to contain_file('mysql-config-file').without_content(/test = true/) }
|
|
|
|
end
|
2014-08-14 20:55:20 +02:00
|
|
|
|
2015-10-13 12:29:42 +02:00
|
|
|
context 'with includedir' do
|
|
|
|
let(:params) {{ :includedir => '/etc/my.cnf.d' }}
|
|
|
|
it 'makes the directory' do
|
|
|
|
is_expected.to contain_file('/etc/my.cnf.d').with({
|
|
|
|
:ensure => :directory,
|
|
|
|
:mode => '0755',
|
|
|
|
})
|
2014-08-14 20:55:20 +02:00
|
|
|
end
|
|
|
|
|
2015-10-13 12:29:42 +02:00
|
|
|
it { is_expected.to contain_file('mysql-config-file').with_content(/!includedir/) }
|
|
|
|
end
|
2014-08-14 20:55:20 +02:00
|
|
|
|
2015-10-13 12:29:42 +02:00
|
|
|
context 'without includedir' do
|
|
|
|
let(:params) {{ :includedir => '' }}
|
|
|
|
it 'shouldnt contain the directory' do
|
|
|
|
is_expected.not_to contain_file('mysql-config-file').with({
|
|
|
|
:ensure => :directory,
|
|
|
|
:mode => '0755',
|
|
|
|
})
|
2014-08-14 20:55:20 +02:00
|
|
|
end
|
2015-10-13 12:29:42 +02:00
|
|
|
|
|
|
|
it { is_expected.to contain_file('mysql-config-file').without_content(/!includedir/) }
|
2014-08-14 20:55:20 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|