Repair this by ensuring calls to mysql include the database name.

A prior commit accidently broke this, meaning that mysql_database
was querying the mysql defaults instead of each individual database
when trying to determine the current collate settings.
This commit is contained in:
Ashley Penney 2014-02-18 14:03:24 -05:00
parent 1bc459d05b
commit 30ce3e0e12
2 changed files with 3 additions and 3 deletions

View file

@ -7,7 +7,7 @@ Puppet::Type.type(:mysql_database).provide(:mysql, :parent => Puppet::Provider::
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 = {}
mysql([defaults_file, '-NBe', "show variables like '%_database'"].compact).split("\n").each do |line| mysql([defaults_file, '-NBe', "show variables like '%_database'", name].compact).split("\n").each do |line|
k,v = line.split(/\s/) k,v = line.split(/\s/)
attributes[k] = v attributes[k] = v
end end

View file

@ -31,7 +31,7 @@ test
Puppet::Util.stubs(:which).with('mysql').returns('/usr/bin/mysql') Puppet::Util.stubs(:which).with('mysql').returns('/usr/bin/mysql')
File.stubs(:file?).with('/root/.my.cnf').returns(true) File.stubs(:file?).with('/root/.my.cnf').returns(true)
provider.class.stubs(:mysql).with([defaults_file, '-NBe', 'show databases']).returns('new_database') provider.class.stubs(:mysql).with([defaults_file, '-NBe', 'show databases']).returns('new_database')
provider.class.stubs(:mysql).with([defaults_file, '-NBe', "show variables like '%_database'"]).returns("character_set_database latin1\ncollation_database latin1_swedish_ci\nskip_show_database OFF") provider.class.stubs(:mysql).with([defaults_file, '-NBe', "show variables like '%_database'", 'new_database']).returns("character_set_database latin1\ncollation_database latin1_swedish_ci\nskip_show_database OFF")
end end
let(:instance) { provider.class.instances.first } let(:instance) { provider.class.instances.first }
@ -40,7 +40,7 @@ test
it 'returns an array of databases' do it 'returns an array of databases' do
provider.class.stubs(:mysql).with([defaults_file, '-NBe', 'show databases']).returns(raw_databases) provider.class.stubs(:mysql).with([defaults_file, '-NBe', 'show databases']).returns(raw_databases)
raw_databases.each_line do |db| raw_databases.each_line do |db|
provider.class.stubs(:mysql).with([defaults_file, '-NBe', "show variables like '%_database'"]).returns("character_set_database latin1\ncollation_database latin1_swedish_ci\nskip_show_database OFF") provider.class.stubs(:mysql).with([defaults_file, '-NBe', "show variables like '%_database'", db.chomp]).returns("character_set_database latin1\ncollation_database latin1_swedish_ci\nskip_show_database OFF")
end end
databases = provider.class.instances.collect {|x| x.name } databases = provider.class.instances.collect {|x| x.name }
parsed_databases.should match_array(databases) parsed_databases.should match_array(databases)