forked from mislav/will_paginate
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path.autotest
54 lines (45 loc) · 1.63 KB
/
.autotest
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
Autotest.add_hook :initialize do |at|
at.libs = 'lib:spec'
at.clear_mappings
at.add_mapping(%r{^lib/will_paginate/(.+)\.rb$}) { |_, match|
"spec/#{match[1]}_spec.rb"
}
at.add_mapping(%r{^spec/.+_spec\.rb$}) { |f, _| f }
at.add_mapping(%r{^spec/(finders/activerecord_test_connector.rb|database.yml|fixtures/.+)$}) {
'spec/finders/active_record_spec.rb'
}
at.add_mapping(%r{^spec/((spec_helper|shared/.+)\.rb|spec.opts)$}) {
# simply re-run all specs
at.files_matching %r{^spec/.+_spec\.rb$}
}
# add these to ignore list
%w{ .git test/ rails/ Rakefile README.rdoc init.rb .autotest
doc/ coverage/ LICENSE CHANGELOG .manifest will_paginate.gemspec examples/
spec/tasks.rake spec/console spec/rcov.opts
}.each { |path| at.add_exception path }
end
Autotest::Rspec.class_eval do
# RSpec guys forgot about `libs` in make_test_cmd
def make_test_cmd_with_libs(files_to_test)
make_test_cmd_without_libs(files_to_test).sub(' -S ', " -S -I#{libs} ")
end
alias :make_test_cmd_without_libs :make_test_cmd
alias :make_test_cmd :make_test_cmd_with_libs
# ugh, we have to monkeypatch Autotest ...
# the regexp it generates for the exception list just matches too much
#
# SOLUTION: wrap it up in another regexp that anchors the whole expression to
# the beginning of the path
def exceptions
unless defined? @exceptions then
if @exception_list.empty? then
@exceptions = nil
else
# old (BAD):
# @exceptions = Regexp.union(*@exception_list)
@exceptions = /^\.\/#{Regexp.union(*@exception_list)}/
end
end
@exceptions
end
end