Update to ruby/mspec@8b54bf3
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@62929 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
587d882d91
commit
e389e2c5cd
@ -25,6 +25,7 @@ require 'mspec/matchers/have_protected_instance_method'
|
|||||||
require 'mspec/matchers/have_public_instance_method'
|
require 'mspec/matchers/have_public_instance_method'
|
||||||
require 'mspec/matchers/have_singleton_method'
|
require 'mspec/matchers/have_singleton_method'
|
||||||
require 'mspec/matchers/include'
|
require 'mspec/matchers/include'
|
||||||
|
require 'mspec/matchers/include_any_of'
|
||||||
require 'mspec/matchers/infinity'
|
require 'mspec/matchers/infinity'
|
||||||
require 'mspec/matchers/match_yaml'
|
require 'mspec/matchers/match_yaml'
|
||||||
require 'mspec/matchers/raise_error'
|
require 'mspec/matchers/raise_error'
|
||||||
|
29
spec/mspec/lib/mspec/matchers/include_any_of.rb
Normal file
29
spec/mspec/lib/mspec/matchers/include_any_of.rb
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
class IncludeAnyOfMatcher
|
||||||
|
def initialize(*expected)
|
||||||
|
@expected = expected
|
||||||
|
end
|
||||||
|
|
||||||
|
def matches?(actual)
|
||||||
|
@actual = actual
|
||||||
|
@expected.each do |e|
|
||||||
|
if @actual.include?(e)
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
def failure_message
|
||||||
|
["Expected #{@actual.inspect}", "to include any of #{@expected.inspect}"]
|
||||||
|
end
|
||||||
|
|
||||||
|
def negative_failure_message
|
||||||
|
["Expected #{@actual.inspect}", "not to include any of #{@expected.inspect}"]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
module MSpecMatchers
|
||||||
|
private def include_any_of(*expected)
|
||||||
|
IncludeAnyOfMatcher.new(*expected)
|
||||||
|
end
|
||||||
|
end
|
42
spec/mspec/spec/matchers/include_any_of_spec.rb
Normal file
42
spec/mspec/spec/matchers/include_any_of_spec.rb
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
require 'spec_helper'
|
||||||
|
require 'mspec/expectations/expectations'
|
||||||
|
require 'mspec/matchers'
|
||||||
|
|
||||||
|
describe IncludeAnyOfMatcher do
|
||||||
|
it "matches when actual includes expected" do
|
||||||
|
IncludeAnyOfMatcher.new(2).matches?([1,2,3]).should == true
|
||||||
|
IncludeAnyOfMatcher.new("b").matches?("abc").should == true
|
||||||
|
end
|
||||||
|
|
||||||
|
it "does not match when actual does not include expected" do
|
||||||
|
IncludeAnyOfMatcher.new(4).matches?([1,2,3]).should == false
|
||||||
|
IncludeAnyOfMatcher.new("d").matches?("abc").should == false
|
||||||
|
end
|
||||||
|
|
||||||
|
it "matches when actual includes all expected" do
|
||||||
|
IncludeAnyOfMatcher.new(3, 2, 1).matches?([1,2,3]).should == true
|
||||||
|
IncludeAnyOfMatcher.new("a", "b", "c").matches?("abc").should == true
|
||||||
|
end
|
||||||
|
|
||||||
|
it "matches when actual includes any expected" do
|
||||||
|
IncludeAnyOfMatcher.new(3, 4, 5).matches?([1,2,3]).should == true
|
||||||
|
IncludeAnyOfMatcher.new("c", "d", "e").matches?("abc").should == true
|
||||||
|
end
|
||||||
|
|
||||||
|
it "does not match when actual does not include any expected" do
|
||||||
|
IncludeAnyOfMatcher.new(4, 5).matches?([1,2,3]).should == false
|
||||||
|
IncludeAnyOfMatcher.new("de").matches?("abc").should == false
|
||||||
|
end
|
||||||
|
|
||||||
|
it "provides a useful failure message" do
|
||||||
|
matcher = IncludeAnyOfMatcher.new(5, 6)
|
||||||
|
matcher.matches?([1,2,3])
|
||||||
|
matcher.failure_message.should == ["Expected [1, 2, 3]", "to include any of [5, 6]"]
|
||||||
|
end
|
||||||
|
|
||||||
|
it "provides a useful negative failure message" do
|
||||||
|
matcher = IncludeAnyOfMatcher.new(1, 2, 3)
|
||||||
|
matcher.matches?([1,2])
|
||||||
|
matcher.negative_failure_message.should == ["Expected [1, 2]", "not to include any of [1, 2, 3]"]
|
||||||
|
end
|
||||||
|
end
|
@ -13,7 +13,6 @@ IMPLS = {
|
|||||||
mri: {
|
mri: {
|
||||||
git: "https://github.com/ruby/ruby.git",
|
git: "https://github.com/ruby/ruby.git",
|
||||||
master: "trunk",
|
master: "trunk",
|
||||||
merge_message: "Update to ruby/spec@",
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -64,7 +63,7 @@ class RubyImplementation
|
|||||||
end
|
end
|
||||||
|
|
||||||
def last_merge_message
|
def last_merge_message
|
||||||
message = @data[:merge_message] || "Merge ruby/spec commit"
|
message = @data[:merge_message] || "Update to ruby/spec@"
|
||||||
message.gsub!("ruby/spec", "ruby/mspec") if MSPEC
|
message.gsub!("ruby/spec", "ruby/mspec") if MSPEC
|
||||||
message
|
message
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user