131 lines
4.7 KiB
Ruby
131 lines
4.7 KiB
Ruby
|
require 'spec_helper'
|
||
|
|
||
|
describe Puppet::Type.type(:mysql_user).provider(:mysql) do
|
||
|
let(:defaults_file) { '--defaults-file=/root/.my.cnf' }
|
||
|
let(:newhash) { '*6C8989366EAF75BB670AD8EA7A7FC1176A95CEF5' }
|
||
|
|
||
|
let(:raw_users) do
|
||
|
<<-SQL_OUTPUT
|
||
|
root@127.0.0.1
|
||
|
root@::1
|
||
|
@localhost
|
||
|
debian-sys-maint@localhost
|
||
|
root@localhost
|
||
|
usvn_user@localhost
|
||
|
@vagrant-ubuntu-raring-64
|
||
|
SQL_OUTPUT
|
||
|
end
|
||
|
|
||
|
let(:parsed_users) { %w(root@127.0.0.1 root@::1 debian-sys-maint@localhost root@localhost usvn_user@localhost) }
|
||
|
|
||
|
let(:resource) { Puppet::Type.type(:mysql_user).new(
|
||
|
{ :ensure => :present,
|
||
|
:password_hash => '*6C8989366EAF75BB670AD8EA7A7FC1176A95CEF4',
|
||
|
:name => 'joe@localhost',
|
||
|
:max_user_connections => '10',
|
||
|
:max_connections_per_hour => '10',
|
||
|
:max_queries_per_hour => '10',
|
||
|
:max_updates_per_hour => '10',
|
||
|
:provider => described_class.name
|
||
|
}
|
||
|
)}
|
||
|
let(:provider) { resource.provider }
|
||
|
|
||
|
before :each do
|
||
|
# Set up the stubs for an instances call.
|
||
|
Facter.stubs(:value).with(:root_home).returns('/root')
|
||
|
Puppet::Util.stubs(:which).with('mysql').returns('/usr/bin/mysql')
|
||
|
File.stubs(:file?).with('/root/.my.cnf').returns(true)
|
||
|
provider.class.stubs(:mysql).with([defaults_file, '-NBe', "SELECT CONCAT(User, '@',Host) AS User FROM mysql.user"]).returns('joe@localhost')
|
||
|
provider.class.stubs(:mysql).with([defaults_file, '-NBe', "SELECT MAX_USER_CONNECTIONS, MAX_CONNECTIONS, MAX_QUESTIONS, MAX_UPDATES, PASSWORD FROM mysql.user WHERE CONCAT(user, '@', host) = 'joe@localhost'"]).returns('10 10 10 10 *6C8989366EAF75BB670AD8EA7A7FC1176A95CEF4')
|
||
|
end
|
||
|
|
||
|
let(:instance) { provider.class.instances.first }
|
||
|
|
||
|
describe 'self.instances' do
|
||
|
it 'returns an array of users' do
|
||
|
provider.class.stubs(:mysql).with([defaults_file, '-NBe', "SELECT CONCAT(User, '@',Host) AS User FROM mysql.user"]).returns(raw_users)
|
||
|
parsed_users.each do |user|
|
||
|
provider.class.stubs(:mysql).with([defaults_file, '-NBe', "SELECT MAX_USER_CONNECTIONS, MAX_CONNECTIONS, MAX_QUESTIONS, MAX_UPDATES, PASSWORD FROM mysql.user WHERE CONCAT(user, '@', host) = '#{user}'"]).returns('10 10 10 10 ')
|
||
|
end
|
||
|
|
||
|
usernames = provider.class.instances.collect {|x| x.name }
|
||
|
parsed_users.should match_array(usernames)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe 'self.prefetch' do
|
||
|
it 'exists' do
|
||
|
provider.class.instances
|
||
|
provider.class.prefetch({})
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe 'create' do
|
||
|
it 'makes a user' do
|
||
|
provider.expects(:mysql).with([defaults_file, '-e', "GRANT USAGE ON *.* TO 'joe'@'localhost' IDENTIFIED BY PASSWORD '*6C8989366EAF75BB670AD8EA7A7FC1176A95CEF4' WITH MAX_USER_CONNECTIONS 10 MAX_CONNECTIONS_PER_HOUR 10 MAX_QUERIES_PER_HOUR 10 MAX_UPDATES_PER_HOUR 10"])
|
||
|
provider.expects(:exists?).returns(true)
|
||
|
provider.create.should be_true
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe 'destroy' do
|
||
|
it 'removes a user if present' do
|
||
|
provider.expects(:mysql).with([defaults_file, '-e', "DROP USER 'joe'@'localhost'"])
|
||
|
provider.expects(:exists?).returns(false)
|
||
|
provider.destroy.should be_true
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe 'exists?' do
|
||
|
it 'checks if user exists' do
|
||
|
instance.exists?.should be_true
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe 'self.defaults_file' do
|
||
|
it 'sets --defaults-file' do
|
||
|
File.stubs(:file?).with('/root/.my.cnf').returns(true)
|
||
|
provider.defaults_file.should eq '--defaults-file=/root/.my.cnf'
|
||
|
end
|
||
|
it 'fails if file missing' do
|
||
|
File.expects(:file?).with('/root/.my.cnf').returns(false)
|
||
|
provider.defaults_file.should be_nil
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe 'password_hash' do
|
||
|
it 'returns a hash' do
|
||
|
instance.password_hash.should == '*6C8989366EAF75BB670AD8EA7A7FC1176A95CEF4'
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe 'password_hash=' do
|
||
|
it 'changes the hash' do
|
||
|
provider.expects(:mysql).with([defaults_file, '-e', "SET PASSWORD FOR 'joe'@'localhost' = '*6C8989366EAF75BB670AD8EA7A7FC1176A95CEF5'"]).returns('0')
|
||
|
|
||
|
provider.expects(:password_hash).returns('*6C8989366EAF75BB670AD8EA7A7FC1176A95CEF5')
|
||
|
provider.password_hash=('*6C8989366EAF75BB670AD8EA7A7FC1176A95CEF5')
|
||
|
end
|
||
|
end
|
||
|
|
||
|
['max_user_connections', 'max_connections_per_hour', 'max_queries_per_hour',
|
||
|
'max_updates_per_hour'].each do |property|
|
||
|
|
||
|
describe property do
|
||
|
it "returns #{property}" do
|
||
|
instance.send("#{property}".to_sym).should == '10'
|
||
|
end
|
||
|
end
|
||
|
|
||
|
describe "#{property}=" do
|
||
|
it "changes #{property}" do
|
||
|
provider.expects(:mysql).with([defaults_file, '-e', "GRANT USAGE ON *.* TO 'joe'@'localhost' WITH #{property.upcase} 42"]).returns('0')
|
||
|
provider.expects(property.to_sym).returns('42')
|
||
|
provider.send("#{property}=".to_sym, '42')
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
end
|