blob: a4d1d5d630f8e90bc644964ed27333df7e26a5c7 (
plain)
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
|
describe :proc_to_s, shared: true do
describe "for a proc created with Proc.new" do
it "returns a description optionally including file and line number" do
Proc.new { "hello" }.send(@method).should =~ /^#<Proc:([^ ]*?)(@([^ ]*)\/to_s\.rb:4)?>$/
end
it "has a binary encoding" do
Proc.new { "hello" }.send(@method).encoding.should == Encoding::BINARY
end
end
describe "for a proc created with lambda" do
it "returns a description including '(lambda)' and optionally including file and line number" do
-> { "hello" }.send(@method).should =~ /^#<Proc:([^ ]*?)(@([^ ]*)\/to_s\.rb:10)? \(lambda\)>$/
end
it "has a binary encoding" do
-> { "hello" }.send(@method).encoding.should == Encoding::BINARY
end
end
describe "for a proc created with proc" do
it "returns a description optionally including file and line number" do
proc { "hello" }.send(@method).should =~ /^#<Proc:([^ ]*?)(@([^ ]*)\/to_s\.rb:16)?>$/
end
it "has a binary encoding" do
proc { "hello" }.send(@method).encoding.should == Encoding::BINARY
end
end
describe "for a proc created with UnboundMethod#to_proc" do
it "returns a description including '(lambda)' and optionally including file and line number" do
def hello; end
method("hello").to_proc.send(@method).should =~ /^#<Proc:([^ ]*?)(@([^ ]*)\/to_s\.rb:22)? \(lambda\)>$/
end
it "has a binary encoding" do
def hello; end
method("hello").to_proc.send(@method).encoding.should == Encoding::BINARY
end
end
describe "for a proc created with Symbol#to_proc" do
it "returns a description including '(&:symbol)'" do
proc = :foobar.to_proc
proc.send(@method).should =~ /^#<Proc:0x\h+\(&:foobar\)>$/
end
it "has a binary encoding" do
proc = :foobar.to_proc
proc.send(@method).encoding.should == Encoding::BINARY
end
end
end
|