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
|
require File.expand_path('../../../spec_helper', __FILE__)
require File.expand_path('../fixtures/classes', __FILE__)
describe "Module#public_method_defined?" do
it "returns true if the named public method is defined by module or its ancestors" do
ModuleSpecs::CountsMixin.public_method_defined?("public_3").should == true
ModuleSpecs::CountsParent.public_method_defined?("public_3").should == true
ModuleSpecs::CountsParent.public_method_defined?("public_2").should == true
ModuleSpecs::CountsChild.public_method_defined?("public_3").should == true
ModuleSpecs::CountsChild.public_method_defined?("public_2").should == true
ModuleSpecs::CountsChild.public_method_defined?("public_1").should == true
end
it "returns false if method is not a public method" do
ModuleSpecs::CountsChild.public_method_defined?("private_3").should == false
ModuleSpecs::CountsChild.public_method_defined?("private_2").should == false
ModuleSpecs::CountsChild.public_method_defined?("private_1").should == false
ModuleSpecs::CountsChild.public_method_defined?("protected_3").should == false
ModuleSpecs::CountsChild.public_method_defined?("protected_2").should == false
ModuleSpecs::CountsChild.public_method_defined?("protected_1").should == false
end
it "returns false if the named method is not defined by the module or its ancestors" do
ModuleSpecs::CountsMixin.public_method_defined?(:public_10).should == false
end
it "accepts symbols for the method name" do
ModuleSpecs::CountsMixin.public_method_defined?(:public_3).should == true
end
not_compliant_on :rubinius do
ruby_version_is ""..."1.9" do
it "raises an ArgumentError if called with a Fixnum" do
lambda {
ModuleSpecs::CountsMixin.public_method_defined?(1)
}.should raise_error(ArgumentError)
end
it "raises a TypeError if not passed a Symbol" do
lambda {
ModuleSpecs::CountsMixin.public_method_defined?(nil)
}.should raise_error(TypeError)
lambda {
ModuleSpecs::CountsMixin.public_method_defined?(false)
}.should raise_error(TypeError)
sym = mock('symbol')
def sym.to_sym() :public_3 end
lambda {
ModuleSpecs::CountsMixin.public_method_defined?(sym)
}.should raise_error(TypeError)
end
end
end
ruby_version_is "1.9" do
it "raises a TypeError if not passed a Symbol" do
lambda {
ModuleSpecs::CountsMixin.public_method_defined?(1)
}.should raise_error(TypeError)
lambda {
ModuleSpecs::CountsMixin.public_method_defined?(nil)
}.should raise_error(TypeError)
lambda {
ModuleSpecs::CountsMixin.public_method_defined?(false)
}.should raise_error(TypeError)
end
end
not_compliant_on :rubinius do
it "raises a TypeError if passed an object that defines #to_sym" do
sym = mock('symbol')
def sym.to_sym() :public_3 end
lambda {
ModuleSpecs::CountsMixin.public_method_defined?(sym)
}.should raise_error(TypeError)
end
end
deviates_on :rubinius do
it "calls #to_sym to coerce the passed object to a Symbol" do
sym = mock('symbol')
def sym.to_sym() :public_3 end
ModuleSpecs::CountsMixin.public_method_defined?(sym).should be_true
end
end
it "accepts any object that is a String type" do
str = mock('public_3')
def str.to_str() 'public_3' end
ModuleSpecs::CountsMixin.public_method_defined?(str).should == true
end
deviates_on :rubinius do
it "raises a TypeError if not passed a String type" do
lambda {
ModuleSpecs::CountsMixin.public_method_defined?(mock('x'))
}.should raise_error(TypeError)
end
end
end
|