From 7adb3181a20f95f657348e76e208cc73334f2c01 Mon Sep 17 00:00:00 2001 From: Spencer Krum Date: Mon, 27 Oct 2014 15:46:39 -0700 Subject: [PATCH 1/2] 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 From 87d39e800c4bf7dbeb24f50e33a9c6a0f575609e Mon Sep 17 00:00:00 2001 From: Colleen Murphy Date: Wed, 5 Nov 2014 11:07:17 +0100 Subject: [PATCH 2/2] Update unit tests to handle new -q flag Updated the rabbitmq_user, rabbitmq_user_permissions, and rabbitmq_vhost spec tests to correctly mock the rabbitmqctl command with the -q flag. Also added one missed -q to a list users call. --- .../provider/rabbitmq_user/rabbitmqctl.rb | 2 +- .../rabbitmq_user/rabbitmqctl_spec.rb | 2 +- .../rabbitmqctl_spec.rb | 32 +++++-------------- .../rabbitmq_vhost/rabbitmqctl_spec.rb | 6 ++-- 4 files changed, 13 insertions(+), 29 deletions(-) diff --git a/lib/puppet/provider/rabbitmq_user/rabbitmqctl.rb b/lib/puppet/provider/rabbitmq_user/rabbitmqctl.rb index 414b423b7..f6bb74b05 100644 --- a/lib/puppet/provider/rabbitmq_user/rabbitmqctl.rb +++ b/lib/puppet/provider/rabbitmq_user/rabbitmqctl.rb @@ -90,7 +90,7 @@ def make_user_admin private def get_user_tags - match = rabbitmqctl('list_users').split(/\n/)[1..-2].collect do |line| + match = rabbitmqctl('-q', 'list_users').split(/\n/).collect do |line| line.match(/^#{Regexp.escape(resource[:name])}\s+\[(.*?)\]/) end.compact.first Set.new(match[1].split(/, /)) if match diff --git a/spec/unit/puppet/provider/rabbitmq_user/rabbitmqctl_spec.rb b/spec/unit/puppet/provider/rabbitmq_user/rabbitmqctl_spec.rb index 74ebacc89..a207139bf 100644 --- a/spec/unit/puppet/provider/rabbitmq_user/rabbitmqctl_spec.rb +++ b/spec/unit/puppet/provider/rabbitmq_user/rabbitmqctl_spec.rb @@ -77,7 +77,7 @@ @provider.admin.should == :false end it 'should fail if admin value is invalid' do - @provider.expects(:rabbitmqctl).with('q', 'list_users').returns <<-EOT + @provider.expects(:rabbitmqctl).with('-q', 'list_users').returns <<-EOT foo fail EOT expect { @provider.admin }.to raise_error(Puppet::Error, /Could not match line/) diff --git a/spec/unit/puppet/provider/rabbitmq_user_permissions/rabbitmqctl_spec.rb b/spec/unit/puppet/provider/rabbitmq_user_permissions/rabbitmqctl_spec.rb index a8824fdf4..649fb7458 100644 --- a/spec/unit/puppet/provider/rabbitmq_user_permissions/rabbitmqctl_spec.rb +++ b/spec/unit/puppet/provider/rabbitmq_user_permissions/rabbitmqctl_spec.rb @@ -15,33 +15,25 @@ @provider_class.instance_variable_set(:@users, nil) end it 'should match user permissions from list' do - @provider.class.expects(:rabbitmqctl).with('list_user_permissions', 'foo').returns <<-EOT -Listing users ... + @provider.class.expects(:rabbitmqctl).with('-q', 'list_user_permissions', 'foo').returns <<-EOT bar 1 2 3 -...done. EOT @provider.exists?.should == {:configure=>"1", :write=>"2", :read=>"3"} end it 'should match user permissions with empty columns' do - @provider.class.expects(:rabbitmqctl).with('list_user_permissions', 'foo').returns <<-EOT -Listing users ... + @provider.class.expects(:rabbitmqctl).with('-q', 'list_user_permissions', 'foo').returns <<-EOT bar 3 -...done. EOT @provider.exists?.should == {:configure=>"", :write=>"", :read=>"3"} end it 'should not match user permissions with more than 3 columns' do - @provider.class.expects(:rabbitmqctl).with('list_user_permissions', 'foo').returns <<-EOT -Listing users ... + @provider.class.expects(:rabbitmqctl).with('-q', 'list_user_permissions', 'foo').returns <<-EOT bar 1 2 3 4 -...done. EOT expect { @provider.exists? }.to raise_error(Puppet::Error, /cannot parse line from list_user_permissions/) end it 'should not match an empty list' do - @provider.class.expects(:rabbitmqctl).with('list_user_permissions', 'foo').returns <<-EOT -Listing users ... -...done. + @provider.class.expects(:rabbitmqctl).with('-q', 'list_user_permissions', 'foo').returns <<-EOT EOT @provider.exists?.should == nil end @@ -59,20 +51,16 @@ end {:configure_permission => '1', :write_permission => '2', :read_permission => '3'}.each do |k,v| it "should be able to retrieve #{k}" do - @provider.class.expects(:rabbitmqctl).with('list_user_permissions', 'foo').returns <<-EOT -Listing users ... + @provider.class.expects(:rabbitmqctl).with('-q', 'list_user_permissions', 'foo').returns <<-EOT bar 1 2 3 -...done. EOT @provider.send(k).should == v end end {:configure_permission => '1', :write_permission => '2', :read_permission => '3'}.each do |k,v| it "should be able to retrieve #{k} after exists has been called" do - @provider.class.expects(:rabbitmqctl).with('list_user_permissions', 'foo').returns <<-EOT -Listing users ... + @provider.class.expects(:rabbitmqctl).with('-q', 'list_user_permissions', 'foo').returns <<-EOT bar 1 2 3 -...done. EOT @provider.exists? @provider.send(k).should == v @@ -83,10 +71,8 @@ :write_permission => ['1', 'foo', '3'] }.each do |perm, columns| it "should be able to sync #{perm}" do - @provider.class.expects(:rabbitmqctl).with('list_user_permissions', 'foo').returns <<-EOT -Listing users ... + @provider.class.expects(:rabbitmqctl).with('-q', 'list_user_permissions', 'foo').returns <<-EOT bar 1 2 3 -...done. EOT @provider.resource[perm] = 'foo' @provider.expects(:rabbitmqctl).with('set_permissions', '-p', 'bar', 'foo', *columns) @@ -94,10 +80,8 @@ end end it 'should only call set_permissions once' do - @provider.class.expects(:rabbitmqctl).with('list_user_permissions', 'foo').returns <<-EOT -Listing users ... + @provider.class.expects(:rabbitmqctl).with('-q', 'list_user_permissions', 'foo').returns <<-EOT bar 1 2 3 -...done. EOT @provider.resource[:configure_permission] = 'foo' @provider.resource[:read_permission] = 'foo' diff --git a/spec/unit/puppet/provider/rabbitmq_vhost/rabbitmqctl_spec.rb b/spec/unit/puppet/provider/rabbitmq_vhost/rabbitmqctl_spec.rb index a1f89ad2c..6c8cce8df 100644 --- a/spec/unit/puppet/provider/rabbitmq_vhost/rabbitmqctl_spec.rb +++ b/spec/unit/puppet/provider/rabbitmq_vhost/rabbitmqctl_spec.rb @@ -12,7 +12,7 @@ @provider = provider_class.new(@resource) end it 'should match vhost names' do - @provider.expects(:rabbitmqctl).with('list_vhosts').returns <<-EOT + @provider.expects(:rabbitmqctl).with('-q', 'list_vhosts').returns <<-EOT Listing vhosts ... foo ...done. @@ -20,14 +20,14 @@ @provider.exists?.should == 'foo' end it 'should not match if no vhosts on system' do - @provider.expects(:rabbitmqctl).with('list_vhosts').returns <<-EOT + @provider.expects(:rabbitmqctl).with('-q', 'list_vhosts').returns <<-EOT Listing vhosts ... ...done. EOT @provider.exists?.should be_nil end it 'should not match if no matching vhosts on system' do - @provider.expects(:rabbitmqctl).with('list_vhosts').returns <<-EOT + @provider.expects(:rabbitmqctl).with('-q', 'list_vhosts').returns <<-EOT Listing vhosts ... fooey ...done.