2019a682cd
Install & configure MySQL database by using utf8_general_ci collation which is the way documented in OpenStack [1] and already the default in puppetlabs-mysql [2]. [1] http://goo.gl/GA5gyZ [2] https://github.com/puppetlabs/puppetlabs-mysql/blob/master/manifests/db.pp#L7 Change-Id: Icc9150a71139d21df25a428cf266903e278a8949 Closes-bug: #1446375
93 lines
2.4 KiB
Ruby
93 lines
2.4 KiB
Ruby
#
|
|
# Unit tests for sahara::db::mysql
|
|
#
|
|
require 'spec_helper'
|
|
|
|
describe 'sahara::db::mysql' do
|
|
|
|
let :pre_condition do
|
|
['include mysql::server']
|
|
end
|
|
|
|
let :params do
|
|
{ :dbname => 'sahara',
|
|
:password => 's3cr3t',
|
|
:user => 'sahara',
|
|
:charset => 'utf8',
|
|
:collate => 'utf8_general_ci',
|
|
:host => '127.0.0.1',
|
|
}
|
|
end
|
|
|
|
shared_examples_for 'sahara mysql database' do
|
|
|
|
context 'when omiting the required parameter password' do
|
|
before { params.delete(:password) }
|
|
it { expect { is_expected.to raise_error(Puppet::Error) } }
|
|
end
|
|
|
|
it 'creates a mysql database' do
|
|
is_expected.to contain_openstacklib__db__mysql('sahara').with(
|
|
:user => params[:user],
|
|
:dbname => params[:dbname],
|
|
:password_hash => '*58C036CDA51D8E8BBBBF2F9EA5ABF111ADA444F0',
|
|
:host => params[:host],
|
|
:charset => params[:charset]
|
|
)
|
|
end
|
|
|
|
context 'overriding allowed_hosts param to array' do
|
|
before :each do
|
|
params.merge!(
|
|
:allowed_hosts => ['127.0.0.1','%']
|
|
)
|
|
end
|
|
|
|
it {
|
|
is_expected.to contain_openstacklib__db__mysql('sahara').with(
|
|
:user => params[:user],
|
|
:dbname => params[:dbname],
|
|
:password_hash => '*58C036CDA51D8E8BBBBF2F9EA5ABF111ADA444F0',
|
|
:host => params[:host],
|
|
:charset => params[:charset],
|
|
:allowed_hosts => ['127.0.0.1','%']
|
|
)}
|
|
end
|
|
|
|
context 'overriding allowed_hosts param to string' do
|
|
before :each do
|
|
params.merge!(
|
|
:allowed_hosts => '192.168.1.1'
|
|
)
|
|
end
|
|
|
|
it {
|
|
is_expected.to contain_openstacklib__db__mysql('sahara').with(
|
|
:user => params[:user],
|
|
:dbname => params[:dbname],
|
|
:password_hash => '*58C036CDA51D8E8BBBBF2F9EA5ABF111ADA444F0',
|
|
:host => params[:host],
|
|
:charset => params[:charset],
|
|
:allowed_hosts => '192.168.1.1'
|
|
)}
|
|
end
|
|
|
|
end
|
|
|
|
context 'on Debian platforms' do
|
|
let :facts do
|
|
{ :osfamily => 'Debian' }
|
|
end
|
|
|
|
it_configures 'sahara mysql database'
|
|
end
|
|
|
|
context 'on RedHat platforms' do
|
|
let :facts do
|
|
{ :osfamily => 'RedHat' }
|
|
end
|
|
|
|
it_configures 'sahara mysql database'
|
|
end
|
|
end
|