From 41ada16595195c93d5bd2daf91ea43f3e98cabb8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Re=CC=81my=20Coutable?= Date: Fri, 23 Sep 2011 00:39:27 +0200 Subject: [PATCH] Allow more complex conditions when searching for guards --- lib/guard.rb | 6 +++++- spec/guard_spec.rb | 41 ++++++++++++++++++++++++++++++----------- 2 files changed, 35 insertions(+), 12 deletions(-) diff --git a/lib/guard.rb b/lib/guard.rb index 6916f90..311cf32 100644 --- a/lib/guard.rb +++ b/lib/guard.rb @@ -56,7 +56,11 @@ module Guard @guards.find_all { |guard| guard.class.to_s.downcase.sub('guard::', '') =~ filter } when Hash filter.inject(@guards) do |matches, (k, v)| - matches.find_all { |guard| guard.send(k).to_sym == v.to_sym } + if k.to_sym == :name + matches.find_all { |guard| guard.class.to_s.downcase.sub('guard::', '') == v.to_s.downcase.gsub('-', '') } + else + matches.find_all { |guard| guard.send(k).to_sym == v.to_sym } + end end else @guards diff --git a/spec/guard_spec.rb b/spec/guard_spec.rb index 080dd97..0fda959 100644 --- a/spec/guard_spec.rb +++ b/spec/guard_spec.rb @@ -63,10 +63,14 @@ describe Guard do subject do guard = ::Guard.setup - @guard_foo_bar = Guard::FooBar.new([], { :group => 'backend' }) - @guard_foo_baz = Guard::FooBaz.new([], { :group => 'frontend' }) - guard.instance_variable_get("@guards").push(@guard_foo_bar) - guard.instance_variable_get("@guards").push(@guard_foo_baz) + @guard_foo_bar_backend = Guard::FooBar.new([], { :group => 'backend' }) + @guard_foo_bar_frontend = Guard::FooBar.new([], { :group => 'frontend' }) + @guard_foo_baz_backend = Guard::FooBaz.new([], { :group => 'backend' }) + @guard_foo_baz_frontend = Guard::FooBaz.new([], { :group => 'frontend' }) + guard.instance_variable_get("@guards").push(@guard_foo_bar_backend) + guard.instance_variable_get("@guards").push(@guard_foo_bar_frontend) + guard.instance_variable_get("@guards").push(@guard_foo_baz_backend) + guard.instance_variable_get("@guards").push(@guard_foo_baz_frontend) guard end @@ -76,11 +80,11 @@ describe Guard do describe "find a guard by as string/symbol" do it "find a guard by a string" do - subject.guards('foo-bar').should eql @guard_foo_bar + subject.guards('foo-bar').should eql @guard_foo_bar_backend end it "find a guard by a symbol" do - subject.guards(:'foo-bar').should eql @guard_foo_bar + subject.guards(:'foo-bar').should eql @guard_foo_bar_backend end it "returns nil if guard is not found" do @@ -90,9 +94,9 @@ describe Guard do describe "find guards matching a regexp" do it "with matches" do - subject.guards(/^foo/).should eql [@guard_foo_bar, @guard_foo_baz] + subject.guards(/^foobar/).should eql [@guard_foo_bar_backend, @guard_foo_bar_frontend] end - + it "without matches" do subject.guards(/foo$/).should eql [] end @@ -100,16 +104,31 @@ describe Guard do describe "find guards by their group" do it "group name is a string" do - subject.guards(:group => 'backend').should eql [@guard_foo_bar] + subject.guards(:group => 'backend').should eql [@guard_foo_bar_backend, @guard_foo_baz_backend] end + it "group name is a symbol" do - subject.guards(:group => :frontend).should eql [@guard_foo_baz] + subject.guards(:group => :frontend).should eql [@guard_foo_bar_frontend, @guard_foo_baz_frontend] end it "returns [] if guard is not found" do subject.guards(:group => :unknown).should eql [] end end + + describe "find guards by their group & name" do + it "group name is a string" do + subject.guards(:group => 'backend', :name => 'foo-bar').should eql [@guard_foo_bar_backend] + end + + it "group name is a symbol" do + subject.guards(:group => :frontend, :name => :'foo-baz').should eql [@guard_foo_baz_frontend] + end + + it "returns [] if guard is not found" do + subject.guards(:group => :unknown, :name => :'foo-baz').should eql [] + end + end end describe ".groups" do @@ -142,7 +161,7 @@ describe Guard do it "with matches" do subject.groups(/^back/).should eql [@group_backend, @group_backflip] end - + it "without matches" do subject.groups(/back$/).should eql [] end