mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
Imported minitest 2.0.2 r6093
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@30347 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
03ca479728
commit
9698217cda
4 changed files with 68 additions and 6 deletions
|
@ -1,3 +1,7 @@
|
||||||
|
Sat Dec 25 13:37:55 2010 Ryan Davis <ryand-ruby@zenspider.com>
|
||||||
|
|
||||||
|
* lib/minitest/*.rb: Imported minitest 2.0.2 r6093.
|
||||||
|
|
||||||
Sat Dec 25 13:05:59 2010 Tanaka Akira <akr@fsij.org>
|
Sat Dec 25 13:05:59 2010 Tanaka Akira <akr@fsij.org>
|
||||||
|
|
||||||
* random.c: parenthesize macro arguments.
|
* random.c: parenthesize macro arguments.
|
||||||
|
|
|
@ -10,11 +10,11 @@ require 'minitest/spec'
|
||||||
class MiniTest::Unit
|
class MiniTest::Unit
|
||||||
attr_accessor :runner
|
attr_accessor :runner
|
||||||
|
|
||||||
def run_benchmarks
|
def run_benchmarks # :nodoc:
|
||||||
_run_anything :benchmark
|
_run_anything :benchmark
|
||||||
end
|
end
|
||||||
|
|
||||||
def benchmark_suite_header suite
|
def benchmark_suite_header suite # :nodoc:
|
||||||
"\n#{suite}\t#{suite.bench_range.join("\t")}"
|
"\n#{suite}\t#{suite.bench_range.join("\t")}"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -301,27 +301,63 @@ class MiniTest::Unit
|
||||||
end
|
end
|
||||||
|
|
||||||
class MiniTest::Spec
|
class MiniTest::Spec
|
||||||
|
##
|
||||||
|
# This is used to define a new benchmark method. You usually don't
|
||||||
|
# use this directly and is intended for those needing to write new
|
||||||
|
# performance curve fits (eg: you need a specific polynomial fit).
|
||||||
|
#
|
||||||
|
# See ::bench_performance_linear for an example of how to use this.
|
||||||
|
|
||||||
def self.bench name, &block
|
def self.bench name, &block
|
||||||
define_method "bench_#{name.gsub(/\W+/, '_')}", &block
|
define_method "bench_#{name.gsub(/\W+/, '_')}", &block
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.bench_range &block
|
def self.bench_range &block
|
||||||
|
return super unless block
|
||||||
|
|
||||||
meta = (class << self; self; end)
|
meta = (class << self; self; end)
|
||||||
meta.send :define_method, "bench_range", &block
|
meta.send :define_method, "bench_range", &block
|
||||||
end
|
end
|
||||||
|
|
||||||
|
##
|
||||||
|
# Create a benchmark that verifies that the performance is linear.
|
||||||
|
#
|
||||||
|
# describe "my class" do
|
||||||
|
# bench_performance_linear "fast_algorithm", 0.9999 do
|
||||||
|
# @obj.fast_algorithm
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
|
||||||
def self.bench_performance_linear name, threshold = 0.9, &work
|
def self.bench_performance_linear name, threshold = 0.9, &work
|
||||||
bench name do
|
bench name do
|
||||||
assert_performance_linear threshold, &work
|
assert_performance_linear threshold, &work
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
##
|
||||||
|
# Create a benchmark that verifies that the performance is constant.
|
||||||
|
#
|
||||||
|
# describe "my class" do
|
||||||
|
# bench_performance_constant "zoom_algorithm!" do
|
||||||
|
# @obj.zoom_algorithm!
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
|
||||||
def self.bench_performance_constant name, threshold = 0.99, &work
|
def self.bench_performance_constant name, threshold = 0.99, &work
|
||||||
bench name do
|
bench name do
|
||||||
assert_performance_constant threshold, &work
|
assert_performance_constant threshold, &work
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
##
|
||||||
|
# Create a benchmark that verifies that the performance is exponential.
|
||||||
|
#
|
||||||
|
# describe "my class" do
|
||||||
|
# bench_performance_exponential "algorithm" do
|
||||||
|
# @obj.algorithm
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
|
||||||
def self.bench_performance_exponential name, threshold = 0.99, &work
|
def self.bench_performance_exponential name, threshold = 0.99, &work
|
||||||
bench name do
|
bench name do
|
||||||
assert_performance_exponential threshold, &work
|
assert_performance_exponential threshold, &work
|
||||||
|
|
|
@ -6,18 +6,40 @@
|
||||||
|
|
||||||
class MockExpectationError < StandardError; end
|
class MockExpectationError < StandardError; end
|
||||||
|
|
||||||
|
##
|
||||||
|
# A simple and clean mock object framework.
|
||||||
|
|
||||||
module MiniTest
|
module MiniTest
|
||||||
|
|
||||||
|
##
|
||||||
|
# All mock objects are an instance of Mock
|
||||||
|
|
||||||
class Mock
|
class Mock
|
||||||
def initialize
|
def initialize # :nodoc:
|
||||||
@expected_calls = {}
|
@expected_calls = {}
|
||||||
@actual_calls = Hash.new {|h,k| h[k] = [] }
|
@actual_calls = Hash.new {|h,k| h[k] = [] }
|
||||||
end
|
end
|
||||||
|
|
||||||
|
##
|
||||||
|
# Expect that method +name+ is called, optionally with +args+, and
|
||||||
|
# returns +retval+.
|
||||||
|
#
|
||||||
|
# @mock.expect(:meaning_of_life, 42)
|
||||||
|
# @mock.meaning_of_life # => 42
|
||||||
|
#
|
||||||
|
# @mock.expect(:do_something_with, true, [some_obj, true])
|
||||||
|
# @mock.do_something_with(some_obj, true) # => true
|
||||||
|
|
||||||
def expect(name, retval, args=[])
|
def expect(name, retval, args=[])
|
||||||
@expected_calls[name] = { :retval => retval, :args => args }
|
@expected_calls[name] = { :retval => retval, :args => args }
|
||||||
self
|
self
|
||||||
end
|
end
|
||||||
|
|
||||||
|
##
|
||||||
|
# Verify that all methods were called as expected. Raises
|
||||||
|
# +MockExpectationError+ if the mock object was not called as
|
||||||
|
# expected.
|
||||||
|
|
||||||
def verify
|
def verify
|
||||||
@expected_calls.each_key do |name|
|
@expected_calls.each_key do |name|
|
||||||
expected = @expected_calls[name]
|
expected = @expected_calls[name]
|
||||||
|
@ -28,7 +50,7 @@ module MiniTest
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
def method_missing(sym, *args)
|
def method_missing(sym, *args) # :nodoc:
|
||||||
raise NoMethodError unless @expected_calls.has_key?(sym)
|
raise NoMethodError unless @expected_calls.has_key?(sym)
|
||||||
raise ArgumentError unless @expected_calls[sym][:args].size == args.size
|
raise ArgumentError unless @expected_calls[sym][:args].size == args.size
|
||||||
retval = @expected_calls[sym][:retval]
|
retval = @expected_calls[sym][:retval]
|
||||||
|
@ -37,7 +59,7 @@ module MiniTest
|
||||||
end
|
end
|
||||||
|
|
||||||
alias :original_respond_to? :respond_to?
|
alias :original_respond_to? :respond_to?
|
||||||
def respond_to?(sym)
|
def respond_to?(sym) # :nodoc:
|
||||||
return true if @expected_calls.has_key?(sym)
|
return true if @expected_calls.has_key?(sym)
|
||||||
return original_respond_to?(sym)
|
return original_respond_to?(sym)
|
||||||
end
|
end
|
||||||
|
|
|
@ -520,7 +520,7 @@ module MiniTest
|
||||||
end
|
end
|
||||||
|
|
||||||
class Unit
|
class Unit
|
||||||
VERSION = "2.0.1" # :nodoc:
|
VERSION = "2.0.2" # :nodoc:
|
||||||
|
|
||||||
attr_accessor :report, :failures, :errors, :skips # :nodoc:
|
attr_accessor :report, :failures, :errors, :skips # :nodoc:
|
||||||
attr_accessor :test_count, :assertion_count # :nodoc:
|
attr_accessor :test_count, :assertion_count # :nodoc:
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue