[前][次][番号順一覧][スレッド一覧]

ruby-changes:21055

From: ryan <ko1@a...>
Date: Sun, 28 Aug 2011 05:37:15 +0900 (JST)
Subject: [ruby-changes:21055] ryan:r33104 (ruby_1_9_3): backported 33102 from trunk

ryan	2011-08-28 05:37:05 +0900 (Sun, 28 Aug 2011)

  New Revision: 33104

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=33104

  Log:
    backported 33102 from trunk

  Modified files:
    branches/ruby_1_9_3/ChangeLog
    branches/ruby_1_9_3/lib/minitest/spec.rb
    branches/ruby_1_9_3/lib/minitest/unit.rb
    branches/ruby_1_9_3/test/minitest/test_minitest_spec.rb

Index: ruby_1_9_3/ChangeLog
===================================================================
--- ruby_1_9_3/ChangeLog	(revision 33103)
+++ ruby_1_9_3/ChangeLog	(revision 33104)
@@ -1,3 +1,10 @@
+Sun Aug 28 05:29:50 2011  Ryan Davis  <ryand-ruby@z...>
+
+	* backport r33102 from trunk.
+
+	* lib/minitest/*: Imported minitest 2.5.1 (r6596)
+	* test/minitest/*: ditto
+
 Sat Aug 27 20:54:54 2011  Kazuki Tsujimoto  <kazuki@c...>
 
 	* backport r33099 from trunk.
Index: ruby_1_9_3/lib/minitest/unit.rb
===================================================================
--- ruby_1_9_3/lib/minitest/unit.rb	(revision 33103)
+++ ruby_1_9_3/lib/minitest/unit.rb	(revision 33104)
@@ -620,7 +620,7 @@
   end
 
   class Unit
-    VERSION = "2.5.0" # :nodoc:
+    VERSION = "2.5.1" # :nodoc:
 
     attr_accessor :report, :failures, :errors, :skips # :nodoc:
     attr_accessor :test_count, :assertion_count       # :nodoc:
Index: ruby_1_9_3/lib/minitest/spec.rb
===================================================================
--- ruby_1_9_3/lib/minitest/spec.rb	(revision 33103)
+++ ruby_1_9_3/lib/minitest/spec.rb	(revision 33104)
@@ -94,11 +94,27 @@
   TYPES = [[//, MiniTest::Spec]]
 
   ##
-  # Register a new type of spec that matches the spec's description. Eg:
+  # Register a new type of spec that matches the spec's description.
+  # This method can take either a Regexp and a spec class or a spec
+  # class and a block that takes the description and returns true if
+  # it matches.
   #
-  #     register_spec_plugin(/Controller$/, MiniTest::Spec::Rails)
+  # Eg:
+  #
+  #     register_spec_type(/Controller$/, MiniTest::Spec::Rails)
+  #
+  # or:
+  #
+  #     register_spec_type(MiniTest::Spec::RailsModel) do |desc|
+  #       desc.superclass == ActiveRecord::Base
+  #     end
 
-  def self.register_spec_type matcher, klass
+  def self.register_spec_type(*args, &block)
+    if block then
+      matcher, klass = block, args.first
+    else
+      matcher, klass = *args
+    end
     TYPES.unshift [matcher, klass]
   end
 
@@ -108,8 +124,13 @@
   #     spec_type("BlahController") # => MiniTest::Spec::Rails
 
   def self.spec_type desc
-    desc = desc.to_s
-    TYPES.find { |re, klass| re === desc }.last
+    TYPES.find { |matcher, klass|
+      if matcher.respond_to? :call then
+        matcher.call desc
+      else
+        matcher === desc.to_s
+      end
+    }.last
   end
 
   @@describe_stack = []
Index: ruby_1_9_3/test/minitest/test_minitest_spec.rb
===================================================================
--- ruby_1_9_3/test/minitest/test_minitest_spec.rb	(revision 33103)
+++ ruby_1_9_3/test/minitest/test_minitest_spec.rb	(revision 33104)
@@ -7,6 +7,11 @@
 require 'minitest/autorun'
 require 'stringio'
 
+class MiniSpecA < MiniTest::Spec; end
+class MiniSpecB < MiniTest::Spec; end
+class ExampleA; end
+class ExampleB < ExampleA; end
+
 describe MiniTest::Spec do
   before do
     @assertion_count = 4
@@ -279,6 +284,38 @@
     return x, y, z, before_list, after_list
   end
 
+  def test_register_spec_type
+    original_types = MiniTest::Spec::TYPES.dup
+
+    assert_equal [[//, MiniTest::Spec]], MiniTest::Spec::TYPES
+
+    MiniTest::Spec.register_spec_type(/woot/, TestMeta)
+
+    p = lambda do |x| true end
+    MiniTest::Spec.register_spec_type TestMeta, &p
+
+    keys = MiniTest::Spec::TYPES.map(&:first)
+
+    assert_includes keys, /woot/
+    assert_includes keys, p
+  ensure
+    MiniTest::Spec::TYPES.replace original_types
+  end
+
+  def test_spec_type
+    original_types = MiniTest::Spec::TYPES.dup
+
+    MiniTest::Spec.register_spec_type(/A$/, MiniSpecA)
+    MiniTest::Spec.register_spec_type MiniSpecB do |desc|
+      desc.superclass == ExampleA
+    end
+
+    assert_equal MiniSpecA, MiniTest::Spec.spec_type(ExampleA)
+    assert_equal MiniSpecB, MiniTest::Spec.spec_type(ExampleB)
+  ensure
+    MiniTest::Spec::TYPES.replace original_types
+  end
+
   def test_structure
     x, y, z, * = util_structure
 

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]