Fixed missing parent for global mysql class
Added "require" to the global mysql.rb file like in the other provider files. defaults-file changed to defaults-extra-file in all the database_* (old) providers, the same as in the mysql_* providers. Changed defaults-file to defaults-extra-file in all test files
This commit is contained in:
parent
e315ee96d0
commit
4ac8879734
12 changed files with 36 additions and 58 deletions
|
@ -294,7 +294,7 @@ sub mysql_setup {
|
||||||
}
|
}
|
||||||
} elsif ( -r "/etc/mysql/debian.cnf" and $doremote == 0 ){
|
} elsif ( -r "/etc/mysql/debian.cnf" and $doremote == 0 ){
|
||||||
# We have a debian maintenance account, use it
|
# We have a debian maintenance account, use it
|
||||||
$mysqllogin = "--defaults-file=/etc/mysql/debian.cnf";
|
$mysqllogin = "--defaults-extra-file=/etc/mysql/debian.cnf";
|
||||||
my $loginstatus = `mysqladmin $mysqllogin ping 2>&1`;
|
my $loginstatus = `mysqladmin $mysqllogin ping 2>&1`;
|
||||||
if ($loginstatus =~ /mysqld is alive/) {
|
if ($loginstatus =~ /mysqld is alive/) {
|
||||||
goodprint "Logged in using credentials from debian maintenance account.\n";
|
goodprint "Logged in using credentials from debian maintenance account.\n";
|
||||||
|
|
|
@ -8,7 +8,7 @@ Puppet::Type.type(:database).provide(:mysql) do
|
||||||
|
|
||||||
def self.defaults_file
|
def self.defaults_file
|
||||||
if File.file?("#{Facter.value(:root_home)}/.my.cnf")
|
if File.file?("#{Facter.value(:root_home)}/.my.cnf")
|
||||||
"--defaults-file=#{Facter.value(:root_home)}/.my.cnf"
|
"--defaults-extra-file=#{Facter.value(:root_home)}/.my.cnf"
|
||||||
else
|
else
|
||||||
nil
|
nil
|
||||||
end
|
end
|
||||||
|
|
|
@ -198,7 +198,7 @@ Puppet::Type.type(:database_grant).provide(:mysql) do
|
||||||
# Optional defaults file
|
# Optional defaults file
|
||||||
def self.defaults_file
|
def self.defaults_file
|
||||||
if File.file?("#{Facter.value(:root_home)}/.my.cnf")
|
if File.file?("#{Facter.value(:root_home)}/.my.cnf")
|
||||||
"--defaults-file=#{Facter.value(:root_home)}/.my.cnf"
|
"--defaults-extra-file=#{Facter.value(:root_home)}/.my.cnf"
|
||||||
else
|
else
|
||||||
nil
|
nil
|
||||||
end
|
end
|
||||||
|
|
|
@ -64,7 +64,7 @@ Puppet::Type.type(:database_user).provide(:mysql) do
|
||||||
# Optional defaults file
|
# Optional defaults file
|
||||||
def self.defaults_file
|
def self.defaults_file
|
||||||
if File.file?("#{Facter.value(:root_home)}/.my.cnf")
|
if File.file?("#{Facter.value(:root_home)}/.my.cnf")
|
||||||
"--defaults-file=#{Facter.value(:root_home)}/.my.cnf"
|
"--defaults-extra-file=#{Facter.value(:root_home)}/.my.cnf"
|
||||||
else
|
else
|
||||||
nil
|
nil
|
||||||
end
|
end
|
||||||
|
|
|
@ -13,6 +13,7 @@ class Puppet::Provider::Mysql < Puppet::Provider
|
||||||
nil
|
nil
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def defaults_file
|
def defaults_file
|
||||||
self.class.defaults_file
|
self.class.defaults_file
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,20 +1,9 @@
|
||||||
Puppet::Type.type(:mysql_database).provide(:mysql) do
|
require File.expand_path(File.join(File.dirname(__FILE__), '..', 'mysql'))
|
||||||
|
Puppet::Type.type(:mysql_database).provide(:mysql, :parent => Puppet::Provider::Mysql) do
|
||||||
desc 'Manages MySQL databases.'
|
desc 'Manages MySQL databases.'
|
||||||
|
|
||||||
commands :mysql => 'mysql'
|
commands :mysql => 'mysql'
|
||||||
|
|
||||||
def self.defaults_file
|
|
||||||
if File.file?("#{Facter.value(:root_home)}/.my.cnf")
|
|
||||||
"--defaults-extra-file=#{Facter.value(:root_home)}/.my.cnf"
|
|
||||||
else
|
|
||||||
nil
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def defaults_file
|
|
||||||
self.class.defaults_file
|
|
||||||
end
|
|
||||||
|
|
||||||
def self.instances
|
def self.instances
|
||||||
mysql([defaults_file, '-NBe', 'show databases'].compact).split("\n").collect do |name|
|
mysql([defaults_file, '-NBe', 'show databases'].compact).split("\n").collect do |name|
|
||||||
attributes = {}
|
attributes = {}
|
||||||
|
|
|
@ -4,18 +4,6 @@ Puppet::Type.type(:mysql_user).provide(:mysql, :parent => Puppet::Provider::Mysq
|
||||||
desc 'manage users for a mysql database.'
|
desc 'manage users for a mysql database.'
|
||||||
commands :mysql => 'mysql'
|
commands :mysql => 'mysql'
|
||||||
|
|
||||||
# Optional defaults file
|
|
||||||
def self.defaults_file
|
|
||||||
if File.file?("#{Facter.value(:root_home)}/.my.cnf")
|
|
||||||
"--defaults-extra-file=#{Facter.value(:root_home)}/.my.cnf"
|
|
||||||
else
|
|
||||||
nil
|
|
||||||
end
|
|
||||||
end
|
|
||||||
def defaults_file
|
|
||||||
self.class.defaults_file
|
|
||||||
end
|
|
||||||
|
|
||||||
# Build a property_hash containing all the discovered information about MySQL
|
# Build a property_hash containing all the discovered information about MySQL
|
||||||
# users.
|
# users.
|
||||||
def self.instances
|
def self.instances
|
||||||
|
|
|
@ -6,7 +6,7 @@ describe provider_class do
|
||||||
subject { provider_class }
|
subject { provider_class }
|
||||||
|
|
||||||
let(:root_home) { '/root' }
|
let(:root_home) { '/root' }
|
||||||
let(:defaults_file) { '--defaults-file=/root/.my.cnf' }
|
let(:defaults_file) { '--defaults-extra-file=/root/.my.cnf' }
|
||||||
|
|
||||||
let(:raw_databases) do
|
let(:raw_databases) do
|
||||||
<<-SQL_OUTPUT
|
<<-SQL_OUTPUT
|
||||||
|
@ -28,7 +28,7 @@ test
|
||||||
Facter.stubs(:value).with(:root_home).returns(root_home)
|
Facter.stubs(:value).with(:root_home).returns(root_home)
|
||||||
Puppet::Util.stubs(:which).with('mysql').returns('/usr/bin/mysql')
|
Puppet::Util.stubs(:which).with('mysql').returns('/usr/bin/mysql')
|
||||||
subject.stubs(:which).with('mysql').returns('/usr/bin/mysql')
|
subject.stubs(:which).with('mysql').returns('/usr/bin/mysql')
|
||||||
subject.stubs(:defaults_file).returns('--defaults-file=/root/.my.cnf')
|
subject.stubs(:defaults_file).returns('--defaults-extra-file=/root/.my.cnf')
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'self.instances' do
|
describe 'self.instances' do
|
||||||
|
@ -77,9 +77,9 @@ test
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'self.defaults_file' do
|
describe 'self.defaults_file' do
|
||||||
it 'sets --defaults-file' do
|
it 'sets --defaults-extra-file' do
|
||||||
File.stubs(:file?).with('#{root_home}/.my.cnf').returns(true)
|
File.stubs(:file?).with('#{root_home}/.my.cnf').returns(true)
|
||||||
@provider.defaults_file.should == '--defaults-file=/root/.my.cnf'
|
@provider.defaults_file.should == '--defaults-extra-file=/root/.my.cnf'
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,7 @@ describe provider_class do
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should query privileges from the database' do
|
it 'should query privileges from the database' do
|
||||||
provider_class.expects(:mysql) .with(["--defaults-file=#{root_home}/.my.cnf", 'mysql', '-Be', 'describe user']).returns <<-EOT
|
provider_class.expects(:mysql) .with(["--defaults-extra-file=#{root_home}/.my.cnf", 'mysql', '-Be', 'describe user']).returns <<-EOT
|
||||||
Field Type Null Key Default Extra
|
Field Type Null Key Default Extra
|
||||||
Host char(60) NO PRI
|
Host char(60) NO PRI
|
||||||
User char(16) NO PRI
|
User char(16) NO PRI
|
||||||
|
@ -27,7 +27,7 @@ Select_priv enum('N','Y') NO N
|
||||||
Insert_priv enum('N','Y') NO N
|
Insert_priv enum('N','Y') NO N
|
||||||
Update_priv enum('N','Y') NO N
|
Update_priv enum('N','Y') NO N
|
||||||
EOT
|
EOT
|
||||||
provider_class.expects(:mysql).with(["--defaults-file=#{root_home}/.my.cnf", 'mysql', '-Be', 'describe db']).returns <<-EOT
|
provider_class.expects(:mysql).with(["--defaults-extra-file=#{root_home}/.my.cnf", 'mysql', '-Be', 'describe db']).returns <<-EOT
|
||||||
Field Type Null Key Default Extra
|
Field Type Null Key Default Extra
|
||||||
Host char(60) NO PRI
|
Host char(60) NO PRI
|
||||||
Db char(64) NO PRI
|
Db char(64) NO PRI
|
||||||
|
@ -41,7 +41,7 @@ EOT
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should query set privileges' do
|
it 'should query set privileges' do
|
||||||
provider_class.expects(:mysql).with(["--defaults-file=#{root_home}/.my.cnf", 'mysql', '-Be', "select * from mysql.user where user='user' and host='host'"]).returns <<-EOT
|
provider_class.expects(:mysql).with(["--defaults-extra-file=#{root_home}/.my.cnf", 'mysql', '-Be', "select * from mysql.user where user='user' and host='host'"]).returns <<-EOT
|
||||||
Host User Password Select_priv Insert_priv Update_priv
|
Host User Password Select_priv Insert_priv Update_priv
|
||||||
host user Y N Y
|
host user Y N Y
|
||||||
EOT
|
EOT
|
||||||
|
@ -49,7 +49,7 @@ EOT
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should recognize when all privileges are set' do
|
it 'should recognize when all privileges are set' do
|
||||||
provider_class.expects(:mysql).with(["--defaults-file=#{root_home}/.my.cnf", 'mysql', '-Be', "select * from mysql.user where user='user' and host='host'"]).returns <<-EOT
|
provider_class.expects(:mysql).with(["--defaults-extra-file=#{root_home}/.my.cnf", 'mysql', '-Be', "select * from mysql.user where user='user' and host='host'"]).returns <<-EOT
|
||||||
Host User Password Select_priv Insert_priv Update_priv
|
Host User Password Select_priv Insert_priv Update_priv
|
||||||
host user Y Y Y
|
host user Y Y Y
|
||||||
EOT
|
EOT
|
||||||
|
@ -57,7 +57,7 @@ EOT
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should recognize when all privileges are not set' do
|
it 'should recognize when all privileges are not set' do
|
||||||
provider_class.expects(:mysql).with(["--defaults-file=#{root_home}/.my.cnf", 'mysql', '-Be', "select * from mysql.user where user='user' and host='host'"]).returns <<-EOT
|
provider_class.expects(:mysql).with(["--defaults-extra-file=#{root_home}/.my.cnf", 'mysql', '-Be', "select * from mysql.user where user='user' and host='host'"]).returns <<-EOT
|
||||||
Host User Password Select_priv Insert_priv Update_priv
|
Host User Password Select_priv Insert_priv Update_priv
|
||||||
host user Y N Y
|
host user Y N Y
|
||||||
EOT
|
EOT
|
||||||
|
@ -65,27 +65,27 @@ EOT
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should be able to set all privileges' do
|
it 'should be able to set all privileges' do
|
||||||
provider_class.expects(:mysql).with(["--defaults-file=#{root_home}/.my.cnf", 'mysql', '-NBe', "SELECT '1' FROM user WHERE user='user' AND host='host'"]).returns "1\n"
|
provider_class.expects(:mysql).with(["--defaults-extra-file=#{root_home}/.my.cnf", 'mysql', '-NBe', "SELECT '1' FROM user WHERE user='user' AND host='host'"]).returns "1\n"
|
||||||
provider_class.expects(:mysql).with(["--defaults-file=#{root_home}/.my.cnf", 'mysql', '-Be', "update user set Select_priv = 'Y', Insert_priv = 'Y', Update_priv = 'Y' where user='user' and host='host'"])
|
provider_class.expects(:mysql).with(["--defaults-extra-file=#{root_home}/.my.cnf", 'mysql', '-Be', "update user set Select_priv = 'Y', Insert_priv = 'Y', Update_priv = 'Y' where user='user' and host='host'"])
|
||||||
provider_class.expects(:mysqladmin).with(%W(--defaults-file=#{root_home}/.my.cnf flush-privileges))
|
provider_class.expects(:mysqladmin).with(%W(--defaults-extra-file=#{root_home}/.my.cnf flush-privileges))
|
||||||
@provider.privileges=(%w(all))
|
@provider.privileges=(%w(all))
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should be able to set partial privileges' do
|
it 'should be able to set partial privileges' do
|
||||||
provider_class.expects(:mysql).with(["--defaults-file=#{root_home}/.my.cnf", 'mysql', '-NBe', "SELECT '1' FROM user WHERE user='user' AND host='host'"]).returns "1\n"
|
provider_class.expects(:mysql).with(["--defaults-extra-file=#{root_home}/.my.cnf", 'mysql', '-NBe', "SELECT '1' FROM user WHERE user='user' AND host='host'"]).returns "1\n"
|
||||||
provider_class.expects(:mysql).with(["--defaults-file=#{root_home}/.my.cnf", 'mysql', '-Be', "update user set Select_priv = 'Y', Insert_priv = 'N', Update_priv = 'Y' where user='user' and host='host'"])
|
provider_class.expects(:mysql).with(["--defaults-extra-file=#{root_home}/.my.cnf", 'mysql', '-Be', "update user set Select_priv = 'Y', Insert_priv = 'N', Update_priv = 'Y' where user='user' and host='host'"])
|
||||||
provider_class.expects(:mysqladmin).with(%W(--defaults-file=#{root_home}/.my.cnf flush-privileges))
|
provider_class.expects(:mysqladmin).with(%W(--defaults-extra-file=#{root_home}/.my.cnf flush-privileges))
|
||||||
@provider.privileges=(%w(Select_priv Update_priv))
|
@provider.privileges=(%w(Select_priv Update_priv))
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should be case insensitive' do
|
it 'should be case insensitive' do
|
||||||
provider_class.expects(:mysql).with(["--defaults-file=#{root_home}/.my.cnf", 'mysql', '-NBe', "SELECT '1' FROM user WHERE user='user' AND host='host'"]).returns "1\n"
|
provider_class.expects(:mysql).with(["--defaults-extra-file=#{root_home}/.my.cnf", 'mysql', '-NBe', "SELECT '1' FROM user WHERE user='user' AND host='host'"]).returns "1\n"
|
||||||
provider_class.expects(:mysql).with(["--defaults-file=#{root_home}/.my.cnf", 'mysql', '-Be', "update user set Select_priv = 'Y', Insert_priv = 'Y', Update_priv = 'Y' where user='user' and host='host'"])
|
provider_class.expects(:mysql).with(["--defaults-extra-file=#{root_home}/.my.cnf", 'mysql', '-Be', "update user set Select_priv = 'Y', Insert_priv = 'Y', Update_priv = 'Y' where user='user' and host='host'"])
|
||||||
provider_class.expects(:mysqladmin).with(["--defaults-file=#{root_home}/.my.cnf", 'flush-privileges'])
|
provider_class.expects(:mysqladmin).with(["--defaults-extra-file=#{root_home}/.my.cnf", 'flush-privileges'])
|
||||||
@provider.privileges=(%w(SELECT_PRIV insert_priv UpDaTe_pRiV))
|
@provider.privileges=(%w(SELECT_PRIV insert_priv UpDaTe_pRiV))
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should not pass --defaults-file if $root_home/.my.cnf is absent' do
|
it 'should not pass --defaults-extra-file if $root_home/.my.cnf is absent' do
|
||||||
File.stubs(:file?).with("#{root_home}/.my.cnf").returns(false)
|
File.stubs(:file?).with("#{root_home}/.my.cnf").returns(false)
|
||||||
provider_class.expects(:mysql).with(['mysql', '-NBe', "SELECT '1' FROM user WHERE user='user' AND host='host'"]).returns "1\n"
|
provider_class.expects(:mysql).with(['mysql', '-NBe', "SELECT '1' FROM user WHERE user='user' AND host='host'"]).returns "1\n"
|
||||||
provider_class.expects(:mysql).with(['mysql', '-Be', "update user set Select_priv = 'Y', Insert_priv = 'N', Update_priv = 'Y' where user='user' and host='host'"])
|
provider_class.expects(:mysql).with(['mysql', '-Be', "update user set Select_priv = 'Y', Insert_priv = 'N', Update_priv = 'Y' where user='user' and host='host'"])
|
||||||
|
|
|
@ -6,7 +6,7 @@ describe provider_class do
|
||||||
subject { provider_class }
|
subject { provider_class }
|
||||||
|
|
||||||
let(:root_home) { '/root' }
|
let(:root_home) { '/root' }
|
||||||
let(:defaults_file) { '--defaults-file=/root/.my.cnf' }
|
let(:defaults_file) { '--defaults-extra-file=/root/.my.cnf' }
|
||||||
let(:newhash) { '*6C8989366EAF75BB670AD8EA7A7FC1176A95CEF5' }
|
let(:newhash) { '*6C8989366EAF75BB670AD8EA7A7FC1176A95CEF5' }
|
||||||
|
|
||||||
let(:raw_users) do
|
let(:raw_users) do
|
||||||
|
@ -35,7 +35,7 @@ usvn_user@localhost
|
||||||
Facter.stubs(:value).with(:root_home).returns(root_home)
|
Facter.stubs(:value).with(:root_home).returns(root_home)
|
||||||
Puppet::Util.stubs(:which).with('mysql').returns('/usr/bin/mysql')
|
Puppet::Util.stubs(:which).with('mysql').returns('/usr/bin/mysql')
|
||||||
subject.stubs(:which).with('mysql').returns('/usr/bin/mysql')
|
subject.stubs(:which).with('mysql').returns('/usr/bin/mysql')
|
||||||
subject.stubs(:defaults_file).returns('--defaults-file=/root/.my.cnf')
|
subject.stubs(:defaults_file).returns('--defaults-extra-file=/root/.my.cnf')
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'self.instances' do
|
describe 'self.instances' do
|
||||||
|
@ -110,9 +110,9 @@ usvn_user@localhost
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'self.defaults_file' do
|
describe 'self.defaults_file' do
|
||||||
it 'sets --defaults-file' do
|
it 'sets --defaults-extra-file' do
|
||||||
File.stubs(:file?).with('#{root_home}/.my.cnf').returns(true)
|
File.stubs(:file?).with('#{root_home}/.my.cnf').returns(true)
|
||||||
@provider.defaults_file.should == '--defaults-file=/root/.my.cnf'
|
@provider.defaults_file.should == '--defaults-extra-file=/root/.my.cnf'
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@ require 'spec_helper'
|
||||||
|
|
||||||
describe Puppet::Type.type(:mysql_database).provider(:mysql) do
|
describe Puppet::Type.type(:mysql_database).provider(:mysql) do
|
||||||
|
|
||||||
let(:defaults_file) { '--defaults-file=/root/.my.cnf' }
|
let(:defaults_file) { '--defaults-extra-file=/root/.my.cnf' }
|
||||||
|
|
||||||
let(:raw_databases) do
|
let(:raw_databases) do
|
||||||
<<-SQL_OUTPUT
|
<<-SQL_OUTPUT
|
||||||
|
@ -77,9 +77,9 @@ test
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'self.defaults_file' do
|
describe 'self.defaults_file' do
|
||||||
it 'sets --defaults-file' do
|
it 'sets --defaults-extra-file' do
|
||||||
File.stubs(:file?).with('/root/.my.cnf').returns(true)
|
File.stubs(:file?).with('/root/.my.cnf').returns(true)
|
||||||
provider.defaults_file.should eq '--defaults-file=/root/.my.cnf'
|
provider.defaults_file.should eq '--defaults-extra-file=/root/.my.cnf'
|
||||||
end
|
end
|
||||||
it 'fails if file missing' do
|
it 'fails if file missing' do
|
||||||
File.stubs(:file?).with('/root/.my.cnf').returns(false)
|
File.stubs(:file?).with('/root/.my.cnf').returns(false)
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe Puppet::Type.type(:mysql_user).provider(:mysql) do
|
describe Puppet::Type.type(:mysql_user).provider(:mysql) do
|
||||||
let(:defaults_file) { '--defaults-file=/root/.my.cnf' }
|
let(:defaults_file) { '--defaults-extra-file=/root/.my.cnf' }
|
||||||
let(:newhash) { '*6C8989366EAF75BB670AD8EA7A7FC1176A95CEF5' }
|
let(:newhash) { '*6C8989366EAF75BB670AD8EA7A7FC1176A95CEF5' }
|
||||||
|
|
||||||
let(:raw_users) do
|
let(:raw_users) do
|
||||||
|
@ -84,9 +84,9 @@ usvn_user@localhost
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'self.defaults_file' do
|
describe 'self.defaults_file' do
|
||||||
it 'sets --defaults-file' do
|
it 'sets --defaults-extra-file' do
|
||||||
File.stubs(:file?).with('/root/.my.cnf').returns(true)
|
File.stubs(:file?).with('/root/.my.cnf').returns(true)
|
||||||
provider.defaults_file.should eq '--defaults-file=/root/.my.cnf'
|
provider.defaults_file.should eq '--defaults-extra-file=/root/.my.cnf'
|
||||||
end
|
end
|
||||||
it 'fails if file missing' do
|
it 'fails if file missing' do
|
||||||
File.expects(:file?).with('/root/.my.cnf').returns(false)
|
File.expects(:file?).with('/root/.my.cnf').returns(false)
|
||||||
|
|
Loading…
Reference in a new issue