blob: ddf185e6d2efd53a92ea1783593331d9f0caaf73 (
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
56
57
58
59
60
61
62
63
64
65
66
67
|
require_relative '../spec_helper'
require_relative 'fixtures/private'
describe "The private keyword" do
it "marks following methods as being private" do
a = Private::A.new
a.methods.should_not include(:bar)
-> { a.bar }.should raise_error(NoMethodError)
b = Private::B.new
b.methods.should_not include(:bar)
-> { b.bar }.should raise_error(NoMethodError)
end
# def expr.meth() methods are always public
it "has no effect on def expr.meth() methods" do
Private::B.public_defs_method.should == 0
end
it "is overridden when a new class is opened" do
c = Private::B::C.new
c.methods.should include(:baz)
c.baz
Private::B.public_class_method1.should == 1
-> { Private::B.private_class_method1 }.should raise_error(NoMethodError)
end
it "is no longer in effect when the class is closed" do
b = Private::B.new
b.methods.should include(:foo)
b.foo
end
it "changes visibility of previously called method" do
klass = Class.new do
def foo
"foo"
end
end
f = klass.new
f.foo
klass.class_eval do
private :foo
end
-> { f.foo }.should raise_error(NoMethodError)
end
it "changes visibility of previously called methods with same send/call site" do
g = ::Private::G.new
-> {
2.times do
g.foo
module ::Private
class G
private :foo
end
end
end
}.should raise_error(NoMethodError)
end
it "changes the visibility of the existing method in the subclass" do
::Private::A.new.foo.should == 'foo'
-> { ::Private::H.new.foo }.should raise_error(NoMethodError)
::Private::H.new.send(:foo).should == 'foo'
end
end
|