test/test.rb in method_source-0.2.0 vs test/test.rb in method_source-0.3.2

- old
+ new

@@ -5,10 +5,12 @@ require "#{direc}/test_helper" describe MethodSource do before do + @hello_module_source = " def hello; :hello_module; end\n" + @hello_singleton_source = "def $o.hello; :hello_singleton; end\n" @hello_source = "def hello; :hello; end\n" @hello_comment = "# A comment for hello\n# It spans two lines and is indented by 2 spaces\n" @lambda_comment = "# This is a comment for MyLambda\n" @lambda_source = "MyLambda = lambda { :lambda }\n" @proc_source = "MyProc = Proc.new { :proc }\n" @@ -19,32 +21,38 @@ UnboundMethod.method_defined?(:source).should == true Proc.method_defined?(:source).should == true end describe "Methods" do - if RUBY_VERSION =~ /1.9/ - it 'should return source for method' do - method(:hello).source.should == @hello_source - end - - it 'should return a comment for method' do - method(:hello).comment.should == @hello_comment - end + it 'should return source for method' do + method(:hello).source.should == @hello_source + end - it 'should raise for C methods' do - lambda { method(:puts).source }.should.raise RuntimeError - end + it 'should return source for a method defined in a module' do + M.instance_method(:hello).source.should == @hello_module_source + end - else - it 'should raise on #source for 1.8' do - lambda { method(:hello).source }.should.raise RuntimeError - end + it 'should return source for a singleton method as an instance method' do + class << $o; self; end.instance_method(:hello).source.should == @hello_singleton_source end + + it 'should return source for a singleton method' do + $o.method(:hello).source.should == @hello_singleton_source + end + + + it 'should return a comment for method' do + method(:hello).comment.should == @hello_comment + end + + it 'should raise for C methods' do + lambda { method(:puts).source }.should.raise RuntimeError + end end - describe "Lambdas and Procs" do - if RUBY_VERSION =~ /1.9/ + if RUBY_VERSION =~ /1.9/ + describe "Lambdas and Procs" do it 'should return source for proc' do MyProc.source.should == @proc_source end it 'should return an empty string if there is no comment' do @@ -56,44 +64,37 @@ end it 'should return comment for lambda' do MyLambda.comment.should == @lambda_comment end - else - it 'should raise on #source for 1.8' do - lambda { method(:hello).source }.should.raise RuntimeError - end end end + describe "Comment tests" do + before do + @comment1 = "# a\n# b\n" + @comment2 = "# a\n# b\n" + @comment3 = "# a\n#\n# b\n" + @comment4 = "# a\n# b\n" + @comment5 = "# a\n# b\n# c\n# d\n" + end - if RUBY_VERSION =~ /1.9/ - describe "Comment tests" do - before do - @comment1 = "# a\n# b\n" - @comment2 = "# a\n# b\n" - @comment3 = "# a\n#\n# b\n" - @comment4 = "# a\n# b\n" - @comment5 = "# a\n# b\n# c\n# d\n" - end + it "should correctly extract multi-line comments" do + method(:comment_test1).comment.should == @comment1 + end - it "should correctly extract multi-line comments" do - method(:comment_test1).comment.should == @comment1 - end + it "should correctly strip leading whitespace before comments" do + method(:comment_test2).comment.should == @comment2 + end - it "should correctly strip leading whitespace before comments" do - method(:comment_test2).comment.should == @comment2 - end - - it "should keep empty comment lines" do - method(:comment_test3).comment.should == @comment3 - end - - it "should ignore blank lines between comments" do - method(:comment_test4).comment.should == @comment4 - end - - it "should align all comments to same indent level" do - method(:comment_test5).comment.should == @comment5 - end + it "should keep empty comment lines" do + method(:comment_test3).comment.should == @comment3 end + + it "should ignore blank lines between comments" do + method(:comment_test4).comment.should == @comment4 + end + + it "should align all comments to same indent level" do + method(:comment_test5).comment.should == @comment5 + end end end