Add @groups attributes to keep track of the groups, ordered as in the Guardfile
This commit is contained in:
parent
6f7ce6feb7
commit
dd86402109
19
lib/guard.rb
19
lib/guard.rb
@ -9,12 +9,13 @@ module Guard
|
|||||||
autoload :Notifier, 'guard/notifier'
|
autoload :Notifier, 'guard/notifier'
|
||||||
|
|
||||||
class << self
|
class << self
|
||||||
attr_accessor :options, :guards, :listener
|
attr_accessor :options, :guards, :groups, :listener
|
||||||
|
|
||||||
# initialize this singleton
|
# initialize this singleton
|
||||||
def setup(options = {})
|
def setup(options = {})
|
||||||
@options = options
|
@options = options
|
||||||
@listener = Listener.select_and_init(@options[:watchdir] ? File.expand_path(@options[:watchdir]) : Dir.pwd)
|
@listener = Listener.select_and_init(@options[:watchdir] ? File.expand_path(@options[:watchdir]) : Dir.pwd)
|
||||||
|
@groups = [:default]
|
||||||
@guards = []
|
@guards = []
|
||||||
|
|
||||||
@options[:notify] && ENV["GUARD_NOTIFY"] != 'false' ? Notifier.turn_on : Notifier.turn_off
|
@options[:notify] && ENV["GUARD_NOTIFY"] != 'false' ? Notifier.turn_on : Notifier.turn_off
|
||||||
@ -81,21 +82,25 @@ module Guard
|
|||||||
listener.start
|
listener.start
|
||||||
end
|
end
|
||||||
|
|
||||||
def add_guard(name, watchers = [], options = {})
|
def add_guard(name, watchers = [], options = {}, group = nil)
|
||||||
if name.downcase == 'ego'
|
if name.to_sym == :ego
|
||||||
UI.deprecation("Guard::Ego is now part of Guard. You can remove it from your Guardfile.")
|
UI.deprecation("Guard::Ego is now part of Guard. You can remove it from your Guardfile.")
|
||||||
else
|
else
|
||||||
guard_class = get_guard_class(name)
|
guard = get_guard_class(name).new(watchers, options, group)
|
||||||
@guards << guard_class.new(watchers, options)
|
@guards << guard
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def add_group(name)
|
||||||
|
@groups << name.to_sym unless name.nil?
|
||||||
|
end
|
||||||
|
|
||||||
def get_guard_class(name)
|
def get_guard_class(name)
|
||||||
try_require = false
|
try_require = false
|
||||||
const_name = name.to_s.downcase.gsub('-', '')
|
const_name = name.to_s.downcase.gsub('-', '')
|
||||||
begin
|
begin
|
||||||
require "guard/#{name.to_s.downcase}" if try_require
|
require "guard/#{name.downcase}" if try_require
|
||||||
self.const_get(self.constants.find {|c| c.to_s.downcase == const_name })
|
self.const_get(self.constants.find { |c| c.to_s.downcase == const_name })
|
||||||
rescue TypeError
|
rescue TypeError
|
||||||
unless try_require
|
unless try_require
|
||||||
try_require = true
|
try_require = true
|
||||||
|
@ -10,13 +10,17 @@ describe Guard do
|
|||||||
subject.should be ::Guard
|
subject.should be ::Guard
|
||||||
end
|
end
|
||||||
|
|
||||||
it "initializes the Guards" do
|
it "initializes @guards" do
|
||||||
::Guard.guards.should be_kind_of(Array)
|
subject.guards.should eql []
|
||||||
|
end
|
||||||
|
|
||||||
|
it "initializes @groups" do
|
||||||
|
Guard.groups.should eql [:default]
|
||||||
end
|
end
|
||||||
|
|
||||||
it "initializes the options" do
|
it "initializes the options" do
|
||||||
opts = { :my_opts => true }
|
opts = { :my_opts => true }
|
||||||
::Guard.setup(opts).options.should include(:my_opts)
|
Guard.setup(opts).options.should include(:my_opts)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "initializes the listener" do
|
it "initializes the listener" do
|
||||||
@ -62,6 +66,96 @@ describe Guard do
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe ".add_guard" do
|
||||||
|
before(:each) do
|
||||||
|
@guard_rspec_class = double('Guard::RSpec')
|
||||||
|
@guard_rspec = double('Guard::RSpec')
|
||||||
|
|
||||||
|
Guard.stub!(:get_guard_class) { @guard_rspec_class }
|
||||||
|
|
||||||
|
Guard.setup
|
||||||
|
end
|
||||||
|
|
||||||
|
it "accepts guard name as string" do
|
||||||
|
@guard_rspec_class.should_receive(:new).and_return(@guard_rspec)
|
||||||
|
|
||||||
|
Guard.add_guard('rspec')
|
||||||
|
end
|
||||||
|
|
||||||
|
it "accepts guard name as symbol" do
|
||||||
|
@guard_rspec_class.should_receive(:new).and_return(@guard_rspec)
|
||||||
|
|
||||||
|
Guard.add_guard(:rspec)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "adds guard to the @guards array" do
|
||||||
|
@guard_rspec_class.should_receive(:new).and_return(@guard_rspec)
|
||||||
|
|
||||||
|
Guard.add_guard(:rspec)
|
||||||
|
|
||||||
|
Guard.guards.should eql [@guard_rspec]
|
||||||
|
end
|
||||||
|
|
||||||
|
context "with no watchers given" do
|
||||||
|
it "gives an empty array of watchers" do
|
||||||
|
@guard_rspec_class.should_receive(:new).with([], {}, nil).and_return(@guard_rspec)
|
||||||
|
|
||||||
|
Guard.add_guard(:rspec, [])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context "with watchers given" do
|
||||||
|
it "give the watchers array" do
|
||||||
|
@guard_rspec_class.should_receive(:new).with([:foo], {}, nil).and_return(@guard_rspec)
|
||||||
|
|
||||||
|
Guard.add_guard(:rspec, [:foo])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context "with no options given" do
|
||||||
|
it "gives an empty hash of options" do
|
||||||
|
@guard_rspec_class.should_receive(:new).with([], {}, nil).and_return(@guard_rspec)
|
||||||
|
|
||||||
|
Guard.add_guard(:rspec, [], {})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context "with options given" do
|
||||||
|
it "give the options hash" do
|
||||||
|
@guard_rspec_class.should_receive(:new).with([], { :foo => true }, nil).and_return(@guard_rspec)
|
||||||
|
|
||||||
|
Guard.add_guard(:rspec, [], { :foo => true })
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context "with the group :backend given" do
|
||||||
|
it "initialize the guard and pass it its group" do
|
||||||
|
@guard_rspec_class.should_receive(:new).with([], {}, :backend).and_return(@guard_rspec)
|
||||||
|
|
||||||
|
Guard.add_guard(:rspec, [], {}, :backend)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
describe ".add_group" do
|
||||||
|
before(:each) do
|
||||||
|
Guard.setup
|
||||||
|
end
|
||||||
|
|
||||||
|
it "accepts group name as string" do
|
||||||
|
Guard.add_group('backend')
|
||||||
|
|
||||||
|
Guard.groups.should eql [:default, :backend]
|
||||||
|
end
|
||||||
|
|
||||||
|
it "accepts group name as symbol" do
|
||||||
|
Guard.add_group(:backend)
|
||||||
|
|
||||||
|
Guard.groups.should eql [:default, :backend]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
describe ".get_guard_class" do
|
describe ".get_guard_class" do
|
||||||
after do
|
after do
|
||||||
[:Classname, :DashedClassName, :Inline].each do |const|
|
[:Classname, :DashedClassName, :Inline].each do |const|
|
||||||
|
Loading…
Reference in New Issue
Block a user