Run guards for new modified files only if any guard match any file (preventing from clearing the screen when no guard will run!).

Signed-off-by: Rémy Coutable <remy@jilion.com>
This commit is contained in:
Rémy Coutable 2011-04-16 23:13:29 +02:00
parent e13bde0411
commit 9b981f5459
13 changed files with 147 additions and 126 deletions

View File

@ -1,4 +1,4 @@
guard('rspec', :version => 2) do guard('rspec', :cli => '-f doc', :version => 2) do
watch(%r{^spec/(.*)_spec\.rb}) watch(%r{^spec/(.*)_spec\.rb})
watch(%r{^lib/(.*)\.rb}) { |m| "spec/#{m[1]}_spec.rb" } watch(%r{^lib/(.*)\.rb}) { |m| "spec/#{m[1]}_spec.rb" }
watch('spec/spec_helper.rb') { "spec" } watch('spec/spec_helper.rb') { "spec" }

View File

@ -33,9 +33,7 @@ module Guard
UI.error "No guards found in Guardfile, please add at least one." UI.error "No guards found in Guardfile, please add at least one."
else else
listener.on_change do |files| listener.on_change do |files|
if Watcher.match_files?(guards, files) run { run_on_change_for_all_guards(files) } if Watcher.match_files?(guards, files)
run { run_on_change_for_all_guards(files) }
end
end end
UI.info "Guard is now watching at '#{Dir.pwd}'" UI.info "Guard is now watching at '#{Dir.pwd}'"
@ -49,11 +47,12 @@ module Guard
paths = Watcher.match_files(guard, files) paths = Watcher.match_files(guard, files)
supervised_task(guard, :run_on_change, paths) unless paths.empty? supervised_task(guard, :run_on_change, paths) unless paths.empty?
end end
# Reparse the whole directory to catch new files modified during the guards run # Reparse the whole directory to catch new files modified during the guards run
new_modified_files = listener.modified_files([Dir.pwd + '/'], :all => true) new_modified_files = listener.modified_files([Dir.pwd + '/'], :all => true)
listener.update_last_event listener.update_last_event
unless new_modified_files.empty? unless new_modified_files.empty?
run { run_on_change_for_all_guards(new_modified_files) } run { run_on_change_for_all_guards(new_modified_files) } if Watcher.match_files?(guards, files)
end end
end end

View File

@ -1,5 +1,6 @@
module Guard module Guard
class Guard class Guard
attr_accessor :watchers, :options attr_accessor :watchers, :options
def initialize(watchers = [], options = {}) def initialize(watchers = [], options = {})

View File

@ -46,7 +46,6 @@ module Guard
false false
end end
def self.mac? def self.mac?
Config::CONFIG['target_os'] =~ /darwin/i Config::CONFIG['target_os'] =~ /darwin/i
end end

View File

@ -1,5 +1,4 @@
require 'spec_helper' require 'spec_helper'
require 'guard/dsl'
describe Guard::Dsl do describe Guard::Dsl do
subject { Guard::Dsl } subject { Guard::Dsl }
@ -8,14 +7,14 @@ describe Guard::Dsl do
::Guard.stub!(:add_guard) ::Guard.stub!(:add_guard)
end end
it "should write an error message when no Guardfile is found" do it "displays an error message when no Guardfile is found" do
Dir.stub!(:pwd).and_return("no_guardfile_here") Dir.stub!(:pwd).and_return("no_guardfile_here")
Guard::UI.should_receive(:error).with("No Guardfile in current folder, please create one.") Guard::UI.should_receive(:error).with("No Guardfile in current folder, please create one.")
lambda { subject.evaluate_guardfile }.should raise_error lambda { subject.evaluate_guardfile }.should raise_error
end end
it "should write an error message when Guardfile is not valid" do it "displays an error message when Guardfile is not valid" do
mock_guardfile_content("This Guardfile is invalid!") mock_guardfile_content("This Guardfile is invalid!")
Guard::UI.should_receive(:error).with(/Invalid Guardfile, original error is:\n/) Guard::UI.should_receive(:error).with(/Invalid Guardfile, original error is:\n/)
@ -23,15 +22,23 @@ describe Guard::Dsl do
end end
describe ".guardfile_include?" do describe ".guardfile_include?" do
it "should detect a guard specified as a string" do it "detects a guard specified by a string with simple quotes" do
mock_guardfile_content("guard 'test'") mock_guardfile_content("guard 'test'")
subject.guardfile_include?('test').should be_true subject.guardfile_include?('test').should be_true
end end
it "should detect a guard specified as a symbol" do it "detects a guard specified by a string with double quotes" do
mock_guardfile_content("guard :test") mock_guardfile_content('guard "test"')
subject.guardfile_include?('test').should be_true
end
it "detects a guard specified by a symbol" do
mock_guardfile_content("guard :test")
subject.guardfile_include?('test').should be_true
end
it "detects a guard wrapped in parentheses" do
mock_guardfile_content("guard(:test)")
subject.guardfile_include?('test').should be_true subject.guardfile_include?('test').should be_true
end end
end end

View File

@ -1,27 +1,27 @@
require 'spec_helper' require 'spec_helper'
describe Guard::Listener do describe Guard::Listener do
subject { described_class } subject { Guard::Listener }
describe ".select_and_init" do describe ".select_and_init" do
before(:each) { @target_os = Config::CONFIG['target_os'] } before(:each) { @target_os = Config::CONFIG['target_os'] }
after(:each) { Config::CONFIG['target_os'] = @target_os } after(:each) { Config::CONFIG['target_os'] = @target_os }
it "should use darwin listener on Mac OS X" do it "uses darwin listener on Mac OS X" do
Config::CONFIG['target_os'] = 'darwin10.4.0' Config::CONFIG['target_os'] = 'darwin10.4.0'
Guard::Darwin.stub(:usable?).and_return(true) Guard::Darwin.stub(:usable?).and_return(true)
Guard::Darwin.should_receive(:new) Guard::Darwin.should_receive(:new)
subject.select_and_init subject.select_and_init
end end
it "should use polling listener on Windows" do it "uses polling listener on Windows" do
Config::CONFIG['target_os'] = 'win32' Config::CONFIG['target_os'] = 'win32'
Guard::Polling.stub(:usable?).and_return(true) Guard::Polling.stub(:usable?).and_return(true)
Guard::Polling.should_receive(:new) Guard::Polling.should_receive(:new)
subject.select_and_init subject.select_and_init
end end
it "should use linux listener on Linux" do it "uses linux listener on Linux" do
Config::CONFIG['target_os'] = 'linux' Config::CONFIG['target_os'] = 'linux'
Guard::Linux.stub(:usable?).and_return(true) Guard::Linux.stub(:usable?).and_return(true)
Guard::Linux.should_receive(:new) Guard::Linux.should_receive(:new)
@ -32,7 +32,7 @@ describe Guard::Listener do
describe "#update_last_event" do describe "#update_last_event" do
subject { described_class.new } subject { described_class.new }
it "should update last_event with time.now" do it "updates last_event with time.now" do
time = Time.now time = Time.now
subject.update_last_event subject.update_last_event
subject.last_event.should >= time subject.last_event.should >= time
@ -40,4 +40,4 @@ describe Guard::Listener do
end end
end end

View File

@ -5,17 +5,17 @@ describe Guard::Darwin do
subject { Guard::Darwin } subject { Guard::Darwin }
if linux? if linux?
it "should not be usable on linux" do it "isn't usable on linux" do
subject.should_not be_usable subject.should_not be_usable
end end
end end
if mac? if mac?
it "should be usable on 10.6" do it "is usable on 10.6" do
subject.should be_usable subject.should be_usable
end end
describe "watch" do describe "#on_change" do
before(:each) do before(:each) do
@results = [] @results = []
@listener = Guard::Darwin.new @listener = Guard::Darwin.new
@ -24,7 +24,7 @@ describe Guard::Darwin do
end end
end end
it "should catch new file" do it "catches new file" do
file = @fixture_path.join("newfile.rb") file = @fixture_path.join("newfile.rb")
File.exists?(file).should be_false File.exists?(file).should be_false
start start
@ -34,7 +34,7 @@ describe Guard::Darwin do
@results.should == ['spec/fixtures/newfile.rb'] @results.should == ['spec/fixtures/newfile.rb']
end end
it "should catch file update" do it "catches file update" do
file = @fixture_path.join("folder1/file1.txt") file = @fixture_path.join("folder1/file1.txt")
File.exists?(file).should be_true File.exists?(file).should be_true
start start
@ -43,7 +43,7 @@ describe Guard::Darwin do
@results.should == ['spec/fixtures/folder1/file1.txt'] @results.should == ['spec/fixtures/folder1/file1.txt']
end end
it "should catch files update" do it "catches files update" do
file1 = @fixture_path.join("folder1/file1.txt") file1 = @fixture_path.join("folder1/file1.txt")
file2 = @fixture_path.join("folder1/folder2/file2.txt") file2 = @fixture_path.join("folder1/folder2/file2.txt")
File.exists?(file1).should be_true File.exists?(file1).should be_true
@ -60,14 +60,14 @@ describe Guard::Darwin do
private private
def start def start
sleep 1 sleep 0.6
Thread.new { @listener.start } Thread.new { @listener.start }
sleep 1 sleep 0.6
end end
def stop def stop
sleep 1 sleep 0.6
@listener.stop @listener.stop
end end
end end

View File

@ -6,17 +6,17 @@ describe Guard::Linux do
subject { Guard::Linux } subject { Guard::Linux }
if mac? if mac?
it "should not be usable on 10.6" do it "isn't usable on 10.6" do
subject.should_not be_usable subject.should_not be_usable
end end
end end
if linux? if linux?
it "should be usable on linux" do it "is usable on linux" do
subject.should be_usable subject.should be_usable
end end
describe "start" do describe "#start" do
before(:each) do before(:each) do
@listener = Guard::Linux.new @listener = Guard::Linux.new
end end
@ -40,7 +40,7 @@ describe Guard::Linux do
end end
describe "watch" do describe "#on_change" do
before(:each) do before(:each) do
@results = [] @results = []
@listener = Guard::Linux.new @listener = Guard::Linux.new
@ -127,4 +127,4 @@ private
sleep 1 sleep 1
end end
end end

View File

@ -11,35 +11,37 @@ describe Guard::Polling do
end end
end end
it "should catch new file" do describe "#on_change" do
file = @fixture_path.join("newfile.rb") it "catches new file" do
File.exists?(file).should be_false file = @fixture_path.join("newfile.rb")
start File.exists?(file).should be_false
FileUtils.touch file start
stop FileUtils.touch file
File.delete file stop
@results.should == ['spec/fixtures/newfile.rb'] File.delete file
end @results.should == ['spec/fixtures/newfile.rb']
end
it "should catch file update" do it "catches file update" do
file = @fixture_path.join("folder1/file1.txt") file = @fixture_path.join("folder1/file1.txt")
File.exists?(file).should be_true File.exists?(file).should be_true
start start
FileUtils.touch file FileUtils.touch file
stop stop
@results.should == ['spec/fixtures/folder1/file1.txt'] @results.should == ['spec/fixtures/folder1/file1.txt']
end end
it "should catch files update" do it "catches files update" do
file1 = @fixture_path.join("folder1/file1.txt") file1 = @fixture_path.join("folder1/file1.txt")
file2 = @fixture_path.join("folder1/folder2/file2.txt") file2 = @fixture_path.join("folder1/folder2/file2.txt")
File.exists?(file1).should be_true File.exists?(file1).should be_true
File.exists?(file2).should be_true File.exists?(file2).should be_true
start start
FileUtils.touch file1 FileUtils.touch file1
FileUtils.touch file2 FileUtils.touch file2
stop stop
@results.sort.should == ['spec/fixtures/folder1/file1.txt', 'spec/fixtures/folder1/folder2/file2.txt'] @results.sort.should == ['spec/fixtures/folder1/file1.txt', 'spec/fixtures/folder1/folder2/file2.txt']
end
end end
private private
@ -54,4 +56,4 @@ private
@listener.stop @listener.stop
end end
end end

View File

@ -3,12 +3,15 @@ require 'spec_helper'
describe Guard::Notifier do describe Guard::Notifier do
subject { Guard::Notifier } subject { Guard::Notifier }
describe "notify" do describe ".notify" do
before(:each) { ENV["GUARD_ENV"] = 'special_test' } before(:each) do
@saved_guard_env = ENV["GUARD_ENV"]
ENV["GUARD_ENV"] = 'dont_mute_notify'
end
if mac? if mac?
require 'growl' require 'growl'
it "should use Growl on Mac OS X" do it "uses Growl on Mac OS X" do
Growl.should_receive(:notify).with("great", Growl.should_receive(:notify).with("great",
:title => "Guard", :title => "Guard",
:icon => Pathname.new(File.dirname(__FILE__)).join('../../images/success.png').to_s, :icon => Pathname.new(File.dirname(__FILE__)).join('../../images/success.png').to_s,
@ -20,7 +23,7 @@ describe Guard::Notifier do
if linux? if linux?
require 'libnotify' require 'libnotify'
it "should use Libnotify on Linux" do it "uses Libnotify on Linux" do
Libnotify.should_receive(:show).with( Libnotify.should_receive(:show).with(
:body => "great", :body => "great",
:summary => 'Guard', :summary => 'Guard',
@ -30,12 +33,12 @@ describe Guard::Notifier do
end end
end end
context "turned off" do describe ".turn_off" do
before(:each) { subject.turn_off } before(:each) { subject.turn_off }
if mac? if mac?
require 'growl' require 'growl'
it "should do nothing" do it "does nothing" do
Growl.should_not_receive(:notify) Growl.should_not_receive(:notify)
subject.notify 'great', :title => 'Guard' subject.notify 'great', :title => 'Guard'
end end
@ -43,14 +46,14 @@ describe Guard::Notifier do
if linux? if linux?
require 'libnotify' require 'libnotify'
it "should do nothing" do it "does nothing" do
Libnotify.should_not_receive(:show) Libnotify.should_not_receive(:show)
subject.notify 'great', :title => 'Guard' subject.notify 'great', :title => 'Guard'
end end
end end
end end
after(:each) { ENV["GUARD_ENV"] = 'test' } after(:each) { ENV["GUARD_ENV"] = @saved_guard_env }
end end
end end

View File

@ -2,62 +2,66 @@ require 'spec_helper'
require 'guard/guard' require 'guard/guard'
describe Guard::Watcher do describe Guard::Watcher do
describe "pattern" do describe "#initialize" do
it "should be required" do describe "pattern parameter" do
expect { Guard::Watcher.new }.to raise_error(ArgumentError) it "is required" do
end expect { Guard::Watcher.new }.to raise_error(ArgumentError)
end
it "can be a string" do
Guard::Watcher.new('spec_helper.rb').pattern.should == 'spec_helper.rb' it "can be a string" do
end Guard::Watcher.new('spec_helper.rb').pattern.should == 'spec_helper.rb'
end
it "can be a regexp" do
Guard::Watcher.new(/spec_helper\.rb/).pattern.should == /spec_helper\.rb/ it "can be a regexp" do
end Guard::Watcher.new(/spec_helper\.rb/).pattern.should == /spec_helper\.rb/
end
describe "string looking like a regex" do
before(:each) { Guard::UI.should_receive(:info).any_number_of_times } describe "can be a string looking like a regex (deprecated)" do
before(:each) { Guard::UI.should_receive(:info).any_number_of_times }
specify { Guard::Watcher.new('^spec_helper.rb').pattern.should == /^spec_helper.rb/ }
specify { Guard::Watcher.new('spec_helper.rb$').pattern.should == /spec_helper.rb$/ } it "and is automatically casted to a regex" do
specify { Guard::Watcher.new('spec_helper\.rb').pattern.should == /spec_helper\.rb/ } Guard::Watcher.new('^spec_helper.rb').pattern.should == /^spec_helper.rb/
specify { Guard::Watcher.new('.*_spec.rb').pattern.should == /.*_spec.rb/ } Guard::Watcher.new('spec_helper.rb$').pattern.should == /spec_helper.rb$/
Guard::Watcher.new('spec_helper\.rb').pattern.should == /spec_helper\.rb/
Guard::Watcher.new('.*_spec.rb').pattern.should == /.*_spec.rb/
end
end
end end
end end
describe "action" do describe "action" do
it "should set action to nil by default" do it "should set action to nil by default" do
Guard::Watcher.new(/spec_helper\.rb/).action.should be_nil Guard::Watcher.new(/spec_helper\.rb/).action.should be_nil
end end
it "should set action with a block" do it "should set action with a block" do
action = lambda { |m| "spec/#{m[1]}_spec.rb" } action = lambda { |m| "spec/#{m[1]}_spec.rb" }
Guard::Watcher.new(%r{^lib/(.*).rb}, action).action.should == action Guard::Watcher.new(%r{^lib/(.*).rb}, action).action.should == action
end end
end end
describe ".match_files" do describe ".match_files" do
before(:all) { @guard = Guard::Guard.new } before(:all) { @guard = Guard::Guard.new }
describe "a watcher's with no action" do describe "a watcher's with no action" do
context "regex pattern" do context "regex pattern" do
before(:all) { @guard.watchers = [Guard::Watcher.new(/.*_spec\.rb/)] } before(:all) { @guard.watchers = [Guard::Watcher.new(/.*_spec\.rb/)] }
it "should return paths as they came" do it "should return paths as they came" do
Guard::Watcher.match_files(@guard, ['guard_rocks_spec.rb']).should == ['guard_rocks_spec.rb'] Guard::Watcher.match_files(@guard, ['guard_rocks_spec.rb']).should == ['guard_rocks_spec.rb']
end end
end end
context "string pattern" do context "string pattern" do
before(:all) { @guard.watchers = [Guard::Watcher.new('guard_rocks_spec.rb')] } before(:all) { @guard.watchers = [Guard::Watcher.new('guard_rocks_spec.rb')] }
it "should return paths as they came" do it "should return paths as they came" do
Guard::Watcher.match_files(@guard, ['guard_rocks_spec.rb']).should == ['guard_rocks_spec.rb'] Guard::Watcher.match_files(@guard, ['guard_rocks_spec.rb']).should == ['guard_rocks_spec.rb']
end end
end end
end end
describe "a watcher's action with an arity equal to 0" do describe "a watcher's action with an arity equal to 0" do
before(:all) do before(:all) do
@guard.watchers = [ @guard.watchers = [
@ -69,7 +73,7 @@ describe Guard::Watcher do
Guard::Watcher.new(/^uptime\.rb/, lambda { `uptime > /dev/null` }) Guard::Watcher.new(/^uptime\.rb/, lambda { `uptime > /dev/null` })
] ]
end end
it "should return paths specified in the watcher's action" do it "should return paths specified in the watcher's action" do
Guard::Watcher.match_files(@guard, ['spec_helper.rb']).should == ['spec'] Guard::Watcher.match_files(@guard, ['spec_helper.rb']).should == ['spec']
end end
@ -89,7 +93,7 @@ describe Guard::Watcher do
Guard::Watcher.match_files(@guard, ['uptime.rb']).should == [] Guard::Watcher.match_files(@guard, ['uptime.rb']).should == []
end end
end end
describe "a watcher's action with an arity equal to 1" do describe "a watcher's action with an arity equal to 1" do
before(:all) do before(:all) do
@guard.watchers = [ @guard.watchers = [
@ -101,7 +105,7 @@ describe Guard::Watcher do
Guard::Watcher.new(/uptime(.*)\.rb/, lambda { |m| `uptime > /dev/null` }) Guard::Watcher.new(/uptime(.*)\.rb/, lambda { |m| `uptime > /dev/null` })
] ]
end end
it "should return paths after watcher's action has been called against them" do it "should return paths after watcher's action has been called against them" do
Guard::Watcher.match_files(@guard, ['lib/my_wonderful_lib.rb']).should == ['spec/my_wonderful_lib_spec.rb'] Guard::Watcher.match_files(@guard, ['lib/my_wonderful_lib.rb']).should == ['spec/my_wonderful_lib_spec.rb']
end end
@ -121,56 +125,56 @@ describe Guard::Watcher do
Guard::Watcher.match_files(@guard, ['uptime.rb']).should == [] Guard::Watcher.match_files(@guard, ['uptime.rb']).should == []
end end
end end
describe "an exception is raised" do describe "an exception is raised" do
before(:all) { @guard.watchers = [Guard::Watcher.new('evil.rb', lambda { raise "EVIL" })] } before(:all) { @guard.watchers = [Guard::Watcher.new('evil.rb', lambda { raise "EVIL" })] }
it "should display an error" do it "should display an error" do
Guard::UI.should_receive(:error).with("Problem with watch action!") Guard::UI.should_receive(:error).with("Problem with watch action!")
Guard::Watcher.match_files(@guard, ['evil.rb']) Guard::Watcher.match_files(@guard, ['evil.rb'])
end end
end end
end end
describe ".match_files?" do describe ".match_files?" do
before(:all) do before(:all) do
@guard1 = Guard::Guard.new([Guard::Watcher.new(/.*_spec\.rb/)]) @guard1 = Guard::Guard.new([Guard::Watcher.new(/.*_spec\.rb/)])
@guard2 = Guard::Guard.new([Guard::Watcher.new('spec_helper.rb', 'spec')]) @guard2 = Guard::Guard.new([Guard::Watcher.new('spec_helper.rb', 'spec')])
@guards = [@guard1, @guard2] @guards = [@guard1, @guard2]
end end
describe "with at least on watcher that match a file given" do describe "with at least on watcher that match a file given" do
specify { Guard::Watcher.match_files?(@guards, ['lib/my_wonderful_lib.rb', 'guard_rocks_spec.rb']).should be_true } specify { Guard::Watcher.match_files?(@guards, ['lib/my_wonderful_lib.rb', 'guard_rocks_spec.rb']).should be_true }
end end
describe "with no watcher matching a file given" do describe "with no watcher matching a file given" do
specify { Guard::Watcher.match_files?(@guards, ['lib/my_wonderful_lib.rb']).should be_false } specify { Guard::Watcher.match_files?(@guards, ['lib/my_wonderful_lib.rb']).should be_false }
end end
end end
describe "#match_file?" do describe "#match_file?" do
describe "string pattern" do describe "string pattern" do
describe "normal string" do describe "normal string" do
subject { Guard::Watcher.new('guard_rocks_spec.rb') } subject { Guard::Watcher.new('guard_rocks_spec.rb') }
specify { subject.match_file?('lib/my_wonderful_lib.rb').should be_false } specify { subject.match_file?('lib/my_wonderful_lib.rb').should be_false }
specify { subject.match_file?('guard_rocks_spec.rb').should be_true } specify { subject.match_file?('guard_rocks_spec.rb').should be_true }
end end
describe "string representing a regexp converted (while deprecation is active)" do describe "string representing a regexp converted (while deprecation is active)" do
subject { Guard::Watcher.new('^guard_rocks_spec\.rb$') } subject { Guard::Watcher.new('^guard_rocks_spec\.rb$') }
specify { subject.match_file?('lib/my_wonderful_lib.rb').should be_false } specify { subject.match_file?('lib/my_wonderful_lib.rb').should be_false }
specify { subject.match_file?('guard_rocks_spec.rb').should be_true } specify { subject.match_file?('guard_rocks_spec.rb').should be_true }
end end
end end
describe "regexp pattern" do describe "regexp pattern" do
subject { Guard::Watcher.new(/.*_spec\.rb/) } subject { Guard::Watcher.new(/.*_spec\.rb/) }
specify { subject.match_file?('lib/my_wonderful_lib.rb').should be_false } specify { subject.match_file?('lib/my_wonderful_lib.rb').should be_false }
specify { subject.match_file?('guard_rocks_spec.rb').should be_true } specify { subject.match_file?('guard_rocks_spec.rb').should be_true }
end end
end end
end end

View File

@ -44,7 +44,7 @@ describe Guard do
end end
describe ".locate_guard" do describe ".locate_guard" do
it "should return guard-rspec gem path" do it "returns guard-rspec gem path" do
guard_path = Guard.locate_guard('rspec') guard_path = Guard.locate_guard('rspec')
guard_path.should match(/^.*\/guard-rspec-.*$/) guard_path.should match(/^.*\/guard-rspec-.*$/)
guard_path.should == guard_path.chomp guard_path.should == guard_path.chomp
@ -54,7 +54,7 @@ describe Guard do
describe ".supervised_task" do describe ".supervised_task" do
subject { ::Guard.setup } subject { ::Guard.setup }
before(:each) do before(:each) do
@g = mock(Guard::Guard) @g = mock(Guard::Guard).as_null_object
subject.guards.push(@g) subject.guards.push(@g)
end end
@ -64,15 +64,15 @@ describe Guard do
@g.stub!(:regular_with_arg).with("given_path") { "i'm a success" } @g.stub!(:regular_with_arg).with("given_path") { "i'm a success" }
end end
it "should not fire the guard with a supervised method without argument" do it "doesn't fire the guard with a supervised method without argument" do
lambda { subject.supervised_task(@g, :regular) }.should_not change(subject.guards, :size) lambda { subject.supervised_task(@g, :regular) }.should_not change(subject.guards, :size)
end end
it "should not fire the guard with a supervised method with argument" do it "doesn't fire the guard with a supervised method with argument" do
lambda { subject.supervised_task(@g, :regular_with_arg, "given_path") }.should_not change(subject.guards, :size) lambda { subject.supervised_task(@g, :regular_with_arg, "given_path") }.should_not change(subject.guards, :size)
end end
it "should return the result of the supervised method" do it "returns the result of the supervised method" do
::Guard.supervised_task(@g, :regular).should be_true ::Guard.supervised_task(@g, :regular).should be_true
::Guard.supervised_task(@g, :regular_with_arg, "given_path").should == "i'm a success" ::Guard.supervised_task(@g, :regular_with_arg, "given_path").should == "i'm a success"
end end
@ -81,18 +81,24 @@ describe Guard do
describe "tasks that raise an exception" do describe "tasks that raise an exception" do
before(:each) { @g.stub!(:failing) { raise "I break your system" } } before(:each) { @g.stub!(:failing) { raise "I break your system" } }
it "should fire the guard" do it "fires the guard" do
lambda { subject.supervised_task(@g, :failing) }.should change(subject.guards, :size).by(-1) lambda { subject.supervised_task(@g, :failing) }.should change(subject.guards, :size).by(-1)
subject.guards.should_not include(@g) subject.guards.should_not include(@g)
end end
it "should return the exception object" do it "returns the exception object" do
failing_result = ::Guard.supervised_task(@g, :failing) failing_result = ::Guard.supervised_task(@g, :failing)
failing_result.should be_kind_of(Exception) failing_result.should be_kind_of(Exception)
failing_result.message.should == 'I break your system' failing_result.message.should == 'I break your system'
end end
end end
end end
describe ".locate_guard" do
it "returns the path of the guard gem" do
Guard.locate_guard('rspec').should == Gem.source_index.find_name("guard-rspec").last.full_gem_path
end
end
end end
end end

View File

@ -10,12 +10,12 @@ puts "Please do not update/create files while tests are running."
RSpec.configure do |config| RSpec.configure do |config|
config.color_enabled = true config.color_enabled = true
config.filter_run :focus => true config.filter_run :focus => true
config.run_all_when_everything_filtered = true config.run_all_when_everything_filtered = true
config.before(:each) do config.before(:each) do
@fixture_path = Pathname.new(File.expand_path('../fixtures/', __FILE__)) @fixture_path = Pathname.new(File.expand_path('../fixtures/', __FILE__))
end end
end end