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 55 56 57 58 59 60 61
|
describe :end_with, shared: true do
# the @method should either be :to_s or :to_sym
it "returns true only if ends match" do
s = "hello".send(@method)
s.should.end_with?('o')
s.should.end_with?('llo')
end
it 'returns false if the end does not match' do
s = 'hello'.send(@method)
s.should_not.end_with?('ll')
end
it "returns true if the search string is empty" do
"hello".send(@method).should.end_with?("")
"".send(@method).should.end_with?("")
end
it "returns true only if any ending match" do
"hello".send(@method).should.end_with?('x', 'y', 'llo', 'z')
end
it "converts its argument using :to_str" do
s = "hello".send(@method)
find = mock('o')
find.should_receive(:to_str).and_return("o")
s.should.end_with?(find)
end
it "ignores arguments not convertible to string" do
"hello".send(@method).should_not.end_with?()
-> { "hello".send(@method).end_with?(1) }.should raise_error(TypeError)
-> { "hello".send(@method).end_with?(["o"]) }.should raise_error(TypeError)
-> { "hello".send(@method).end_with?(1, nil, "o") }.should raise_error(TypeError)
end
it "uses only the needed arguments" do
find = mock('h')
find.should_not_receive(:to_str)
"hello".send(@method).should.end_with?("o", find)
end
it "works for multibyte strings" do
"céréale".send(@method).should.end_with?("réale")
end
it "raises an Encoding::CompatibilityError if the encodings are incompatible" do
pat = "ア".encode Encoding::EUC_JP
-> do
"あれ".send(@method).end_with?(pat)
end.should raise_error(Encoding::CompatibilityError)
end
it "checks that we are starting to match at the head of a character" do
"\xC3\xA9".send(@method).should_not.end_with?("\xA9")
"\xe3\x81\x82".send(@method).should_not.end_with?("\x82")
"ab".force_encoding("UTF-16BE").send(@method).should_not.end_with?(
"b".force_encoding("UTF-16BE"))
end
end
|