From 7adb3181a20f95f657348e76e208cc73334f2c01 Mon Sep 17 00:00:00 2001 From: Spencer Krum Date: Mon, 27 Oct 2014 15:46:39 -0700 Subject: [PATCH] Use -q flag instead of array slices Previously we sliced off the informational output lines. This broke on rabbitmq 3.4.0 because the 'done' was removed. We can use the -q flag to never print them in the first place. --- .../provider/rabbitmq_user/rabbitmqctl.rb | 4 +- .../rabbitmq_user_permissions/rabbitmqctl.rb | 2 +- .../provider/rabbitmq_vhost/rabbitmqctl.rb | 4 +- .../rabbitmq_user/rabbitmqctl_spec.rb | 77 +++++-------------- 4 files changed, 24 insertions(+), 63 deletions(-) diff --git a/lib/puppet/provider/rabbitmq_user/rabbitmqctl.rb b/lib/puppet/provider/rabbitmq_user/rabbitmqctl.rb index ef284bdcd..414b423b7 100644 --- a/lib/puppet/provider/rabbitmq_user/rabbitmqctl.rb +++ b/lib/puppet/provider/rabbitmq_user/rabbitmqctl.rb @@ -13,7 +13,7 @@ defaultfor :feature => :posix def self.instances - rabbitmqctl('list_users').split(/\n/)[1..-2].collect do |line| + rabbitmqctl('-q', 'list_users').split(/\n/).collect do |line| if line =~ /^(\S+)(\s+\[.*?\]|)$/ new(:name => $1) else @@ -37,7 +37,7 @@ def destroy end def exists? - rabbitmqctl('list_users').split(/\n/)[1..-2].detect do |line| + rabbitmqctl('-q', 'list_users').split(/\n/).detect do |line| line.match(/^#{Regexp.escape(resource[:name])}(\s+(\[.*?\]|\S+)|)$/) end end diff --git a/lib/puppet/provider/rabbitmq_user_permissions/rabbitmqctl.rb b/lib/puppet/provider/rabbitmq_user_permissions/rabbitmqctl.rb index 83bd808e2..9d5f1e098 100644 --- a/lib/puppet/provider/rabbitmq_user_permissions/rabbitmqctl.rb +++ b/lib/puppet/provider/rabbitmq_user_permissions/rabbitmqctl.rb @@ -15,7 +15,7 @@ def self.users(name, vhost) @users = {} unless @users unless @users[name] @users[name] = {} - rabbitmqctl('list_user_permissions', name).split(/\n/)[1..-2].each do |line| + rabbitmqctl('-q', 'list_user_permissions', name).split(/\n/).each do |line| if line =~ /^(\S+)\s+(\S*)\s+(\S*)\s+(\S*)$/ @users[name][$1] = {:configure => $2, :read => $4, :write => $3} diff --git a/lib/puppet/provider/rabbitmq_vhost/rabbitmqctl.rb b/lib/puppet/provider/rabbitmq_vhost/rabbitmqctl.rb index 2ee45c311..836cff19a 100644 --- a/lib/puppet/provider/rabbitmq_vhost/rabbitmqctl.rb +++ b/lib/puppet/provider/rabbitmq_vhost/rabbitmqctl.rb @@ -9,7 +9,7 @@ end def self.instances - rabbitmqctl('list_vhosts').split(/\n/)[1..-2].map do |line| + rabbitmqctl('-q', 'list_vhosts').split(/\n/).map do |line| if line =~ /^(\S+)$/ new(:name => $1) else @@ -27,7 +27,7 @@ def destroy end def exists? - out = rabbitmqctl('list_vhosts').split(/\n/)[1..-2].detect do |line| + out = rabbitmqctl('-q', 'list_vhosts').split(/\n/).detect do |line| line.match(/^#{Regexp.escape(resource[:name])}$/) end end diff --git a/spec/unit/puppet/provider/rabbitmq_user/rabbitmqctl_spec.rb b/spec/unit/puppet/provider/rabbitmq_user/rabbitmqctl_spec.rb index 2c13b886a..74ebacc89 100644 --- a/spec/unit/puppet/provider/rabbitmq_user/rabbitmqctl_spec.rb +++ b/spec/unit/puppet/provider/rabbitmq_user/rabbitmqctl_spec.rb @@ -12,44 +12,34 @@ @provider = provider_class.new(@resource) end it 'should match user names' do - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT foo -...done. EOT @provider.exists?.should == 'foo' end it 'should match user names with 2.4.1 syntax' do - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT foo bar -...done. EOT @provider.exists?.should == 'foo bar' end it 'should not match if no users on system' do - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... -...done. + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT EOT @provider.exists?.should be_nil end it 'should not match if no matching users on system' do - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT fooey -...done. EOT @provider.exists?.should be_nil end it 'should match user names from list' do - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT one two three foo bar -...done. EOT @provider.exists?.should == 'foo' end @@ -62,13 +52,11 @@ @resource[:password] = 'bar' @resource[:admin] = 'true' @provider.expects(:rabbitmqctl).with('add_user', 'foo', 'bar') - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT foo [] icinga [monitoring] kitchen [] kitchen2 [abc, def, ghi] -...done. EOT @provider.expects(:rabbitmqctl).with('set_user_tags', 'foo', ['administrator']) @provider.create @@ -78,99 +66,81 @@ @provider.destroy end it 'should be able to retrieve admin value' do - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT foo [administrator] -...done. EOT @provider.admin.should == :true - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT one [administrator] foo [] -...done. EOT @provider.admin.should == :false end it 'should fail if admin value is invalid' do - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('q', 'list_users').returns <<-EOT foo fail -...done. EOT expect { @provider.admin }.to raise_error(Puppet::Error, /Could not match line/) end it 'should be able to set admin value' do - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT foo [] icinga [monitoring] kitchen [] kitchen2 [abc, def, ghi] -...done. EOT @provider.expects(:rabbitmqctl).with('set_user_tags', 'foo', ['administrator']) @provider.admin=:true end it 'should not interfere with existing tags on the user when setting admin value' do - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT foo [bar, baz] icinga [monitoring] kitchen [] kitchen2 [abc, def, ghi] -...done. EOT @provider.expects(:rabbitmqctl).with('set_user_tags', 'foo', ['bar','baz', 'administrator'].sort) @provider.admin=:true end it 'should be able to unset admin value' do - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT foo [administrator] guest [administrator] icinga [] -...done. EOT @provider.expects(:rabbitmqctl).with('set_user_tags', 'foo', []) @provider.admin=:false end it 'should not interfere with existing tags on the user when unsetting admin value' do - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT foo [administrator, bar, baz] icinga [monitoring] kitchen [] kitchen2 [abc, def, ghi] -...done. EOT @provider.expects(:rabbitmqctl).with('set_user_tags', 'foo', ['bar','baz'].sort) @provider.admin=:false end it 'should clear all tags on existing user' do - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT one [administrator] foo [tag1,tag2] icinga [monitoring] kitchen [] kitchen2 [abc, def, ghi] -...done. EOT @provider.expects(:rabbitmqctl).with('set_user_tags', 'foo', []) @provider.tags=[] end it 'should set multiple tags' do - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT one [administrator] foo [] icinga [monitoring] kitchen [] kitchen2 [abc, def, ghi] -...done. EOT @provider.expects(:rabbitmqctl).with('set_user_tags', 'foo', ['tag1','tag2']) @provider.tags=['tag1','tag2'] @@ -178,14 +148,12 @@ it 'should clear tags while keep admin tag' do @resource[:admin] = true - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT one [administrator] foo [administrator, tag1, tag2] icinga [monitoring] kitchen [] kitchen2 [abc, def, ghi] -...done. EOT @provider.expects(:rabbitmqctl).with('set_user_tags', 'foo', ["administrator"]) @provider.tags=[] @@ -193,14 +161,12 @@ it 'should change tags while keep admin tag' do @resource[:admin] = true - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT one [administrator] foo [administrator, tag1, tag2] icinga [monitoring] kitchen [] kitchen2 [abc, def, ghi] -...done. EOT @provider.expects(:rabbitmqctl).with('set_user_tags', 'foo', ["administrator","tag1","tag3","tag7"]) @provider.tags=['tag1','tag7','tag3'] @@ -210,10 +176,8 @@ @resource[:tags] = [ "tag1", "tag2" ] @provider.expects(:rabbitmqctl).with('add_user', 'foo', 'bar') @provider.expects(:rabbitmqctl).with('set_user_tags', 'foo', ["tag1","tag2"]) - @provider.expects(:rabbitmqctl).with('list_users').returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT foo [] -...done. EOT @provider.create end @@ -222,15 +186,12 @@ @resource[:tags] = [ "tag1", "tag2" ] @resource[:admin] = true @provider.expects(:rabbitmqctl).with('add_user', 'foo', 'bar') - @provider.expects(:rabbitmqctl).with('list_users').twice.returns <<-EOT -Listing users ... + @provider.expects(:rabbitmqctl).with('-q', 'list_users').twice.returns <<-EOT foo [] -...done. EOT @provider.expects(:rabbitmqctl).with('set_user_tags', 'foo', ["administrator"]) @provider.expects(:rabbitmqctl).with('set_user_tags', 'foo', ["administrator","tag1","tag2"]) @provider.create end - end