mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
ae36cf62b7
Ignore prepended modules when looking for already defined methods on a class to set the visibility on. [Fix GH-1834] From: Dylan Thacker-Smith <Dylan.Smith@shopify.com> git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@62725 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
93 lines
2.1 KiB
Ruby
93 lines
2.1 KiB
Ruby
require_relative '../../spec_helper'
|
|
require_relative 'fixtures/classes'
|
|
require_relative 'shared/set_visibility'
|
|
|
|
describe "Module#private" do
|
|
it_behaves_like :set_visibility, :private
|
|
|
|
it "makes the target method uncallable from other types" do
|
|
obj = Object.new
|
|
class << obj
|
|
def foo; true; end
|
|
end
|
|
|
|
obj.foo.should == true
|
|
|
|
class << obj
|
|
private :foo
|
|
end
|
|
|
|
lambda { obj.foo }.should raise_error(NoMethodError)
|
|
end
|
|
|
|
it "makes a public Object instance method private in a new module" do
|
|
m = Module.new do
|
|
private :module_specs_public_method_on_object
|
|
end
|
|
|
|
m.should have_private_instance_method(:module_specs_public_method_on_object)
|
|
|
|
# Ensure we did not change Object's method
|
|
Object.should_not have_private_instance_method(:module_specs_public_method_on_object)
|
|
end
|
|
|
|
it "makes a public Object instance method private in Kernel" do
|
|
Kernel.should have_private_instance_method(
|
|
:module_specs_public_method_on_object_for_kernel_private)
|
|
Object.should_not have_private_instance_method(
|
|
:module_specs_public_method_on_object_for_kernel_private)
|
|
end
|
|
|
|
it "returns self" do
|
|
(class << Object.new; self; end).class_eval do
|
|
def foo; end
|
|
private(:foo).should equal(self)
|
|
private.should equal(self)
|
|
end
|
|
end
|
|
|
|
it "raises a NameError when given an undefined name" do
|
|
lambda do
|
|
Module.new.send(:private, :undefined)
|
|
end.should raise_error(NameError)
|
|
end
|
|
|
|
it "only makes the method private in the class it is called on" do
|
|
base = Class.new do
|
|
def wrapped
|
|
1
|
|
end
|
|
end
|
|
|
|
klass = Class.new(base) do
|
|
def wrapped
|
|
super + 1
|
|
end
|
|
private :wrapped
|
|
end
|
|
|
|
base.new.wrapped.should == 1
|
|
lambda do
|
|
klass.new.wrapped
|
|
end.should raise_error(NameError)
|
|
end
|
|
|
|
it "continues to allow a prepended module method to call super" do
|
|
wrapper = Module.new do
|
|
def wrapped
|
|
super + 1
|
|
end
|
|
end
|
|
|
|
klass = Class.new do
|
|
prepend wrapper
|
|
|
|
def wrapped
|
|
1
|
|
end
|
|
private :wrapped
|
|
end
|
|
|
|
klass.new.wrapped.should == 2
|
|
end
|
|
end
|