2011-12-02 01:55:48 -05:00
|
|
|
require 'helper'
|
|
|
|
|
|
|
|
describe Pry::WrappedModule do
|
|
|
|
|
|
|
|
describe "#initialize" do
|
|
|
|
it "should raise an exception when a non-module is passed" do
|
|
|
|
lambda{ Pry::WrappedModule.new(nil) }.should.raise ArgumentError
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-06-23 04:14:10 -04:00
|
|
|
describe "candidates" do
|
|
|
|
before do
|
|
|
|
class Host
|
|
|
|
source_files = [File.join(File.dirname(__FILE__), "candidate_helper1.rb"),
|
|
|
|
File.join(File.dirname(__FILE__), "candidate_helper2.rb")]
|
|
|
|
|
|
|
|
source_files.each do |file|
|
|
|
|
binding.eval File.read(file), file, 1
|
|
|
|
end
|
|
|
|
|
|
|
|
# rank 2
|
|
|
|
class CandidateTest
|
|
|
|
def test6
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "number_of_candidates" do
|
|
|
|
it 'should return the correct number of candidates' do
|
|
|
|
Pry::WrappedModule(Host::CandidateTest).number_of_candidates.should == 3
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "ordering of candidates" do
|
|
|
|
it 'should return class with largest number of methods as primary candidate' do
|
|
|
|
Pry::WrappedModule(Host::CandidateTest).candidate(0).file.should =~ /helper1/
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'should return class with second largest number of methods as second ranked candidate' do
|
|
|
|
Pry::WrappedModule(Host::CandidateTest).candidate(1).file.should =~ /helper2/
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'should return class with third largest number of methods as third ranked candidate' do
|
|
|
|
Pry::WrappedModule(Host::CandidateTest).candidate(2).file.should =~ /#{__FILE__}/
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'should raise when trying to access non-existent candidate' do
|
|
|
|
lambda { Pry::WrappedModule(Host::CandidateTest).candidate(3) }.should.raise Pry::CommandError
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "source" do
|
|
|
|
it 'should return primary candidates source by default' do
|
|
|
|
wm = Pry::WrappedModule(Host::CandidateTest)
|
|
|
|
wm.source.should == wm.candidate(0).source
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'should return source for highest ranked candidate' do
|
|
|
|
Pry::WrappedModule(Host::CandidateTest).candidate(0).source.should =~ /test1/
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'should return source for second ranked candidate' do
|
|
|
|
Pry::WrappedModule(Host::CandidateTest).candidate(1).source.should =~ /test4/
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'should return source for third ranked candidate' do
|
|
|
|
Pry::WrappedModule(Host::CandidateTest).candidate(2).source.should =~ /test6/
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "doc" do
|
|
|
|
it 'should return primary candidates doc by default' do
|
|
|
|
wm = Pry::WrappedModule(Host::CandidateTest)
|
|
|
|
wm.doc.should == wm.candidate(0).doc
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'should return doc for highest ranked candidate' do
|
|
|
|
Pry::WrappedModule(Host::CandidateTest).candidate(0).doc.should =~ /rank 0/
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'should return doc for second ranked candidate' do
|
|
|
|
Pry::WrappedModule(Host::CandidateTest).candidate(1).doc.should =~ /rank 1/
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'should return doc for third ranked candidate' do
|
|
|
|
Pry::WrappedModule(Host::CandidateTest).candidate(2).doc.should =~ /rank 2/
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
Object.remove_const(:Host)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-12-02 01:55:48 -05:00
|
|
|
describe ".method_prefix" do
|
|
|
|
before do
|
|
|
|
Foo = Class.new
|
|
|
|
@foo = Foo.new
|
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
Object.remove_const(:Foo)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should return Foo# for normal classes" do
|
|
|
|
Pry::WrappedModule.new(Foo).method_prefix.should == "Foo#"
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should return Bar# for modules" do
|
|
|
|
Pry::WrappedModule.new(Kernel).method_prefix.should == "Kernel#"
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should return Foo. for singleton classes of classes" do
|
|
|
|
Pry::WrappedModule.new(class << Foo; self; end).method_prefix.should == "Foo."
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "of singleton classes of objects" do
|
|
|
|
Pry::WrappedModule.new(class << @foo; self; end).method_prefix.should == "self."
|
|
|
|
end
|
2011-12-19 02:04:14 -05:00
|
|
|
|
|
|
|
describe "of anonymous classes should not be empty" do
|
|
|
|
Pry::WrappedModule.new(Class.new).method_prefix.should =~ /#<Class:.*>#/
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "of singleton classes of anonymous classes should not be empty" do
|
|
|
|
Pry::WrappedModule.new(class << Class.new; self; end).method_prefix.should =~ /#<Class:.*>./
|
|
|
|
end
|
2011-12-02 01:55:48 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
describe ".singleton_class?" do
|
|
|
|
it "should be true for singleton classes" do
|
|
|
|
Pry::WrappedModule.new(class << ""; self; end).singleton_class?.should == true
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should be false for normal classes" do
|
|
|
|
Pry::WrappedModule.new(Class.new).singleton_class?.should == false
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should be false for modules" do
|
|
|
|
Pry::WrappedModule.new(Module.new).singleton_class?.should == false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe ".singleton_instance" do
|
|
|
|
it "should raise an exception when called on a non-singleton-class" do
|
|
|
|
lambda{ Pry::WrappedModule.new(Class).singleton_instance }.should.raise ArgumentError
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should return the attached object" do
|
|
|
|
Pry::WrappedModule.new(class << "hi"; self; end).singleton_instance.should == "hi"
|
|
|
|
Pry::WrappedModule.new(class << Object; self; end).singleton_instance.should.equal?(Object)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|