1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00
ruby--ruby/test/rdoc/test_rdoc_context_section.rb
naruse 07b10cd59f * lib/rdoc/test_case.rb (RDoc::TestCase#verbose_capture_io):
defined for asserts of warnings.

* test/rdoc: use verbose_capture_io on asserts of warnings.
  they failed when tests was run with RUBYOPT=-W0.

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@37978 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2012-11-29 07:01:46 +00:00

137 lines
3.5 KiB
Ruby

require 'rdoc/test_case'
class TestRDocContextSection < RDoc::TestCase
def setup
super
@top_level = @store.add_file 'file.rb'
@klass = @top_level.add_class RDoc::NormalClass, 'Object'
@S = RDoc::Context::Section
@s = @S.new @klass, 'section', comment('# comment', @top_level)
end
def mu_pp obj
s = ''
s = PP.pp obj, s
s.force_encoding Encoding.default_external if defined? Encoding
s.chomp
end
def test_add_comment
file1 = @store.add_file 'file1.rb'
klass = file1.add_class RDoc::NormalClass, 'Klass'
c1 = RDoc::Comment.new "# :section: section\n", file1
c2 = RDoc::Comment.new "# hello\n", file1
c3 = RDoc::Comment.new "# world\n", file1
s = @S.new klass, 'section', c1
assert_empty s.comments
s.add_comment nil
assert_empty s.comments
s.add_comment c2
assert_equal [c2], s.comments
s.add_comment c3
assert_equal [c2, c3], s.comments
end
def test_aref
assert_equal 'section', @s.aref
assert_equal '5Buntitled-5D', @S.new(nil, nil, nil).aref
assert_equal 'one+two', @S.new(nil, 'one two', nil).aref
end
def test_extract_comment
assert_equal '', @s.extract_comment(comment('')).text
assert_equal '', @s.extract_comment(comment("# :section: b\n")).text
assert_equal '# c', @s.extract_comment(comment("# :section: b\n# c")).text
assert_equal '# c',
@s.extract_comment(comment("# a\n# :section: b\n# c")).text
end
def test_marshal_dump
loaded = Marshal.load Marshal.dump @s
expected = RDoc::Comment.new('comment', @top_level).parse
expected = doc(expected)
assert_equal 'section', loaded.title
assert_equal expected, loaded.comments
assert_nil loaded.parent, 'parent is set manually'
end
def test_marshal_dump_no_comment
s = @S.new @klass, 'section', comment('')
loaded = Marshal.load Marshal.dump s
assert_equal 'section', loaded.title
assert_empty loaded.comments
assert_nil loaded.parent, 'parent is set manually'
end
def test_marshal_load_version_0
loaded = Marshal.load "\x04\bU:\eRDoc::Context::Section" +
"[\bi\x00I\"\fsection\x06:\x06EFo" +
":\eRDoc::Markup::Document\a:\v@parts" +
"[\x06o;\a\a;\b[\x06o" +
":\x1CRDoc::Markup::Paragraph\x06;\b" +
"[\x06I\"\fcomment\x06;\x06F:\n@fileI" +
"\"\ffile.rb\x06;\x06F;\n0"
expected = doc RDoc::Comment.new('comment', @top_level).parse
assert_equal 'section', loaded.title
assert_equal expected, loaded.comments
assert_nil loaded.parent, 'parent is set manually'
end
def test_remove_comment_array
other = @store.add_file 'other.rb'
other_comment = comment('bogus', other)
@s.add_comment other_comment
@s.remove_comment comment('bogus', @top_level)
assert_equal [other_comment], @s.comments
end
def test_remove_comment_document
other = @store.add_file 'other.rb'
other_comment = comment('bogus', other)
@s.add_comment other_comment
loaded = Marshal.load Marshal.dump @s
loaded.remove_comment comment('bogus', @top_level)
assert_equal doc(other_comment.parse), loaded.comments
end
def test_sequence
_, err = verbose_capture_io do
assert_match(/\ASEC\d{5}\Z/, @s.sequence)
end
assert_equal "#{@S}#sequence is deprecated, use #aref\n", err
end
end