Merge pull request #878 from bmjen/fix-grants

(MODULES-3716) Fix mysql_grant tests
This commit is contained in:
Hunter Haugen 2016-08-17 14:49:18 -07:00 committed by GitHub
commit 4aa98b14ed
3 changed files with 24 additions and 20 deletions

View file

@ -1,18 +1,9 @@
require 'spec_helper_acceptance' require 'spec_helper_acceptance'
require 'puppet' require 'puppet'
require 'puppet/util/package' require 'puppet/util/package'
require_relative './mysql_helper.rb'
describe 'mysql::server::backup class' do describe 'mysql::server::backup class' do
def pre_run
apply_manifest("class { 'mysql::server': root_password => 'password' }", :catch_failures => true)
@mysql_version = (on default, 'mysql --version').output.chomp.match(/\d+\.\d+\.\d+/)[0]
end
def version_is_greater_than(version)
return Puppet::Util::Package.versioncmp(@mysql_version, version) > 0
end
context 'should work with no errors' do context 'should work with no errors' do
it 'when configuring mysql backups' do it 'when configuring mysql backups' do
pp = <<-EOS pp = <<-EOS

View file

@ -0,0 +1,8 @@
def pre_run
apply_manifest("class { 'mysql::server': root_password => 'password' }", :catch_failures => true)
@mysql_version = (on default, 'mysql --version').output.chomp.match(/\d+\.\d+\.\d+/)[0]
end
def version_is_greater_than(version)
return Puppet::Util::Package.versioncmp(@mysql_version, version) > 0
end

View file

@ -1,16 +1,18 @@
require 'spec_helper_acceptance' require 'spec_helper_acceptance'
require 'puppet'
require 'puppet/util/package'
require_relative '../mysql_helper.rb'
describe 'mysql_grant' do describe 'mysql_grant' do
before(:all) do
describe 'setup' do
it 'setup mysql::server' do
pp = <<-EOS pp = <<-EOS
class { 'mysql::server': } class { 'mysql::server':
root_password => 'password',
}
EOS EOS
apply_manifest(pp, :catch_failures => true) apply_manifest(pp, :catch_failures => true)
end end
end
describe 'missing privileges for user' do describe 'missing privileges for user' do
it 'should fail' do it 'should fail' do
@ -414,7 +416,7 @@ describe 'mysql_grant' do
pp = <<-EOS pp = <<-EOS
if $::operatingsystem == 'Ubuntu' and versioncmp($::operatingsystemmajrelease, '16.00') > 0 { if $::operatingsystem == 'Ubuntu' and versioncmp($::operatingsystemmajrelease, '16.00') > 0 {
exec { 'simpleproc-create': exec { 'simpleproc-create':
command => 'mysql --database=mysql --delimiter="//" -NBe "CREATE PROCEDURE simpleproc (OUT param1 INT) BEGIN SELECT COUNT(*) INTO param1 FROM t; end//"', command => 'mysql --user="root" --password="password" --database=mysql --delimiter="//" -NBe "CREATE PROCEDURE simpleproc (OUT param1 INT) BEGIN SELECT COUNT(*) INTO param1 FROM t; end//"',
path => '/usr/bin/', path => '/usr/bin/',
before => Mysql_user['test2@tester'], before => Mysql_user['test2@tester'],
} }
@ -484,8 +486,11 @@ describe 'mysql_grant' do
end end
it 'should fail with fqdn' do it 'should fail with fqdn' do
pre_run
if ! version_is_greater_than('5.7.0')
expect(shell("mysql -NBe \"SHOW GRANTS FOR test@fqdn.com\"", { :acceptable_exit_codes => 1}).stderr).to match(/There is no such grant defined for user 'test' on host 'fqdn.com'/) expect(shell("mysql -NBe \"SHOW GRANTS FOR test@fqdn.com\"", { :acceptable_exit_codes => 1}).stderr).to match(/There is no such grant defined for user 'test' on host 'fqdn.com'/)
end end
end
it 'finds ipv4' do it 'finds ipv4' do
shell("mysql -NBe \"SHOW GRANTS FOR 'test'@'192.168.5.7'\"") do |r| shell("mysql -NBe \"SHOW GRANTS FOR 'test'@'192.168.5.7'\"") do |r|
expect(r.stdout).to match(/GRANT ALL PRIVILEGES ON `test`.* TO 'test'@'192.168.5.7'/) expect(r.stdout).to match(/GRANT ALL PRIVILEGES ON `test`.* TO 'test'@'192.168.5.7'/)