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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
# -*- encoding: utf-8 -*-
require_relative '../../spec_helper'
require_relative 'fixtures/classes'
describe "String#ljust with length, padding" do
it "returns a new string of specified length with self left justified and padded with padstr" do
"hello".ljust(20, '1234').should == "hello123412341234123"
"".ljust(1, "abcd").should == "a"
"".ljust(2, "abcd").should == "ab"
"".ljust(3, "abcd").should == "abc"
"".ljust(4, "abcd").should == "abcd"
"".ljust(6, "abcd").should == "abcdab"
"OK".ljust(3, "abcd").should == "OKa"
"OK".ljust(4, "abcd").should == "OKab"
"OK".ljust(6, "abcd").should == "OKabcd"
"OK".ljust(8, "abcd").should == "OKabcdab"
end
it "pads with whitespace if no padstr is given" do
"hello".ljust(20).should == "hello "
end
it "returns self if it's longer than or as long as the specified length" do
"".ljust(0).should == ""
"".ljust(-1).should == ""
"hello".ljust(4).should == "hello"
"hello".ljust(-1).should == "hello"
"this".ljust(3).should == "this"
"radiology".ljust(8, '-').should == "radiology"
end
ruby_version_is ''...'2.7' do
it "taints result when self or padstr is tainted" do
"x".taint.ljust(4).tainted?.should == true
"x".taint.ljust(0).tainted?.should == true
"".taint.ljust(0).tainted?.should == true
"x".taint.ljust(4, "*").tainted?.should == true
"x".ljust(4, "*".taint).tainted?.should == true
end
end
it "tries to convert length to an integer using to_int" do
"^".ljust(3.8, "_^").should == "^_^"
obj = mock('3')
obj.should_receive(:to_int).and_return(3)
"o".ljust(obj, "_o").should == "o_o"
end
it "raises a TypeError when length can't be converted to an integer" do
-> { "hello".ljust("x") }.should raise_error(TypeError)
-> { "hello".ljust("x", "y") }.should raise_error(TypeError)
-> { "hello".ljust([]) }.should raise_error(TypeError)
-> { "hello".ljust(mock('x')) }.should raise_error(TypeError)
end
it "tries to convert padstr to a string using to_str" do
padstr = mock('123')
padstr.should_receive(:to_str).and_return("123")
"hello".ljust(10, padstr).should == "hello12312"
end
it "raises a TypeError when padstr can't be converted" do
-> { "hello".ljust(20, []) }.should raise_error(TypeError)
-> { "hello".ljust(20, Object.new)}.should raise_error(TypeError)
-> { "hello".ljust(20, mock('x')) }.should raise_error(TypeError)
end
it "raises an ArgumentError when padstr is empty" do
-> { "hello".ljust(10, '') }.should raise_error(ArgumentError)
end
it "returns subclass instances when called on subclasses" do
StringSpecs::MyString.new("").ljust(10).should be_an_instance_of(StringSpecs::MyString)
StringSpecs::MyString.new("foo").ljust(10).should be_an_instance_of(StringSpecs::MyString)
StringSpecs::MyString.new("foo").ljust(10, StringSpecs::MyString.new("x")).should be_an_instance_of(StringSpecs::MyString)
"".ljust(10, StringSpecs::MyString.new("x")).should be_an_instance_of(String)
"foo".ljust(10, StringSpecs::MyString.new("x")).should be_an_instance_of(String)
end
ruby_version_is ''...'2.7' do
it "when padding is tainted and self is untainted returns a tainted string if and only if length is longer than self" do
"hello".ljust(4, 'X'.taint).tainted?.should be_false
"hello".ljust(5, 'X'.taint).tainted?.should be_false
"hello".ljust(6, 'X'.taint).tainted?.should be_true
end
end
describe "with width" do
it "returns a String in the same encoding as the original" do
str = "abc".force_encoding Encoding::IBM437
result = str.ljust 5
result.should == "abc "
result.encoding.should equal(Encoding::IBM437)
end
end
describe "with width, pattern" do
it "returns a String in the compatible encoding" do
str = "abc".force_encoding Encoding::IBM437
result = str.ljust 5, "あ"
result.should == "abcああ"
result.encoding.should equal(Encoding::UTF_8)
end
it "raises an Encoding::CompatibilityError if the encodings are incompatible" do
pat = "ア".encode Encoding::EUC_JP
-> do
"あれ".ljust 5, pat
end.should raise_error(Encoding::CompatibilityError)
end
end
end
|