aboutsummaryrefslogtreecommitdiffstats
path: root/activesupport/lib/active_support/testing
diff options
context:
space:
mode:
authorYves Senn <yves.senn@gmail.com>2015-06-08 12:05:12 +0200
committerYves Senn <yves.senn@gmail.com>2015-06-08 12:05:12 +0200
commite8d02ccf8c485cd2e5f6e32713bd8fc23b7b5560 (patch)
treed6b8e1a26a3e69e38f14c2e61f698ab8e0fe5042 /activesupport/lib/active_support/testing
parent8e7f8ef5d6209367734530b258f5fbeb0fc24c28 (diff)
parentb6fc8e25a10cc4abdd03018798b180270d6c5d7f (diff)
downloadrails-e8d02ccf8c485cd2e5f6e32713bd8fc23b7b5560.tar.gz
rails-e8d02ccf8c485cd2e5f6e32713bd8fc23b7b5560.tar.bz2
rails-e8d02ccf8c485cd2e5f6e32713bd8fc23b7b5560.zip
Merge pull request #19571 from kaspth/improve-runner-integration
Improve Test Runner's Minitest integration.
Diffstat (limited to 'activesupport/lib/active_support/testing')
-rw-r--r--activesupport/lib/active_support/testing/composite_filter.rb54
1 files changed, 54 insertions, 0 deletions
diff --git a/activesupport/lib/active_support/testing/composite_filter.rb b/activesupport/lib/active_support/testing/composite_filter.rb
new file mode 100644
index 0000000000..bde723e30b
--- /dev/null
+++ b/activesupport/lib/active_support/testing/composite_filter.rb
@@ -0,0 +1,54 @@
+require 'method_source'
+
+module ActiveSupport
+ module Testing
+ class CompositeFilter # :nodoc:
+ def initialize(runnable, filter, patterns)
+ @runnable = runnable
+ @filters = [ derive_regexp(filter), *derive_line_filters(patterns) ].compact
+ end
+
+ def ===(method)
+ @filters.any? { |filter| filter === method }
+ end
+
+ private
+ def derive_regexp(filter)
+ filter =~ %r%/(.*)/% ? Regexp.new($1) : filter
+ end
+
+ def derive_line_filters(patterns)
+ patterns.map do |file_and_line|
+ file, line = file_and_line.split(':')
+ Filter.new(@runnable, file, line) if file
+ end
+ end
+
+ class Filter # :nodoc:
+ def initialize(runnable, file, line)
+ @runnable, @file = runnable, File.expand_path(file)
+ @line = line.to_i if line
+ end
+
+ def ===(method)
+ return unless @runnable.method_defined?(method)
+
+ if @line
+ test_file, test_range = definition_for(@runnable.instance_method(method))
+ test_file == @file && test_range.include?(@line)
+ else
+ @runnable.instance_method(method).source_location.first == @file
+ end
+ end
+
+ private
+ def definition_for(method)
+ file, start_line = method.source_location
+ end_line = method.source.count("\n") + start_line - 1
+
+ return file, start_line..end_line
+ end
+ end
+ end
+ end
+end