2011-08-23 19:53:49 -04:00
|
|
|
# coding: US-ASCII
|
2015-12-16 00:07:31 -05:00
|
|
|
# frozen_string_literal: false
|
2011-08-23 19:53:49 -04:00
|
|
|
|
2010-04-01 03:45:16 -04:00
|
|
|
require File.expand_path '../xref_test_case', __FILE__
|
|
|
|
|
|
|
|
class TestRDocCodeObject < XrefTestCase
|
|
|
|
|
|
|
|
def setup
|
|
|
|
super
|
|
|
|
|
|
|
|
@co = RDoc::CodeObject.new
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_initialize
|
|
|
|
assert @co.document_self, 'document_self'
|
|
|
|
assert @co.document_children, 'document_children'
|
|
|
|
refute @co.force_documentation, 'force_documentation'
|
|
|
|
refute @co.done_documenting, 'done_documenting'
|
2010-12-19 22:22:49 -05:00
|
|
|
refute @co.received_nodoc, 'received_nodoc'
|
2010-04-01 03:45:16 -04:00
|
|
|
assert_equal '', @co.comment, 'comment is empty'
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_comment_equals
|
|
|
|
@co.comment = ''
|
|
|
|
|
|
|
|
assert_equal '', @co.comment
|
|
|
|
|
|
|
|
@co.comment = 'I am a comment'
|
|
|
|
|
|
|
|
assert_equal 'I am a comment', @co.comment
|
|
|
|
end
|
|
|
|
|
2012-11-26 23:28:14 -05:00
|
|
|
def test_comment_equals_comment
|
|
|
|
@co.comment = comment ''
|
|
|
|
|
|
|
|
assert_equal '', @co.comment.text
|
|
|
|
|
|
|
|
@co.comment = comment 'I am a comment'
|
|
|
|
|
|
|
|
assert_equal 'I am a comment', @co.comment.text
|
|
|
|
end
|
|
|
|
|
2011-06-16 00:59:24 -04:00
|
|
|
def test_comment_equals_document
|
|
|
|
doc = RDoc::Markup::Document.new
|
|
|
|
@co.comment = doc
|
|
|
|
|
|
|
|
@co.comment = ''
|
|
|
|
|
|
|
|
assert_equal doc, @co.comment
|
|
|
|
end
|
|
|
|
|
2011-02-01 19:32:30 -05:00
|
|
|
def test_comment_equals_encoding
|
|
|
|
refute_equal Encoding::UTF_8, ''.encoding, 'Encoding sanity check'
|
|
|
|
|
|
|
|
input = 'text'
|
|
|
|
input.force_encoding Encoding::UTF_8
|
|
|
|
|
|
|
|
@co.comment = input
|
|
|
|
|
|
|
|
assert_equal 'text', @co.comment
|
|
|
|
assert_equal Encoding::UTF_8, @co.comment.encoding
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_comment_equals_encoding_blank
|
|
|
|
refute_equal Encoding::UTF_8, ''.encoding, 'Encoding sanity check'
|
|
|
|
|
|
|
|
input = ''
|
|
|
|
input.force_encoding Encoding::UTF_8
|
|
|
|
|
|
|
|
@co.comment = input
|
|
|
|
|
|
|
|
assert_equal '', @co.comment
|
|
|
|
assert_equal Encoding::UTF_8, @co.comment.encoding
|
|
|
|
end
|
|
|
|
|
2011-07-30 20:19:00 -04:00
|
|
|
def test_display_eh_document_self
|
|
|
|
assert @co.display?
|
|
|
|
|
|
|
|
@co.document_self = false
|
|
|
|
|
|
|
|
refute @co.display?
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_display_eh_ignore
|
|
|
|
assert @co.display?
|
|
|
|
|
|
|
|
@co.ignore
|
|
|
|
|
|
|
|
refute @co.display?
|
|
|
|
|
|
|
|
@co.stop_doc
|
|
|
|
|
|
|
|
refute @co.display?
|
|
|
|
|
|
|
|
@co.done_documenting = false
|
|
|
|
|
|
|
|
refute @co.display?
|
|
|
|
end
|
|
|
|
|
2013-09-18 19:33:36 -04:00
|
|
|
def test_display_eh_suppress
|
|
|
|
assert @co.display?
|
|
|
|
|
|
|
|
@co.suppress
|
|
|
|
|
|
|
|
refute @co.display?
|
|
|
|
|
|
|
|
@co.comment = comment('hi')
|
|
|
|
|
|
|
|
refute @co.display?
|
|
|
|
|
|
|
|
@co.done_documenting = false
|
|
|
|
|
|
|
|
assert @co.display?
|
|
|
|
|
|
|
|
@co.ignore
|
|
|
|
@co.done_documenting = false
|
|
|
|
|
|
|
|
refute @co.display?
|
|
|
|
end
|
|
|
|
|
2010-04-01 03:45:16 -04:00
|
|
|
def test_document_children_equals
|
|
|
|
@co.document_children = false
|
2013-09-18 19:33:36 -04:00
|
|
|
|
2010-04-01 03:45:16 -04:00
|
|
|
refute @co.document_children
|
|
|
|
|
2013-09-18 19:33:36 -04:00
|
|
|
@store.rdoc.options.visibility = :nodoc
|
|
|
|
|
|
|
|
@co.store = @store
|
2013-09-19 03:22:13 -04:00
|
|
|
|
2013-09-18 19:33:36 -04:00
|
|
|
assert @co.document_children
|
|
|
|
|
|
|
|
@co.document_children = false
|
|
|
|
|
|
|
|
assert @co.document_children
|
2010-04-01 03:45:16 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_document_self_equals
|
|
|
|
@co.document_self = false
|
|
|
|
refute @co.document_self
|
|
|
|
|
2013-09-18 19:33:36 -04:00
|
|
|
@store.rdoc.options.visibility = :nodoc
|
|
|
|
|
|
|
|
@co.store = @store
|
2013-09-19 03:22:13 -04:00
|
|
|
|
2013-09-18 19:33:36 -04:00
|
|
|
assert @co.document_self
|
|
|
|
|
|
|
|
@co.document_self = false
|
|
|
|
|
|
|
|
assert @co.document_self
|
2010-04-01 03:45:16 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_documented_eh
|
|
|
|
refute @co.documented?
|
|
|
|
|
|
|
|
@co.comment = 'hi'
|
|
|
|
|
|
|
|
assert @co.documented?
|
|
|
|
|
|
|
|
@co.comment.replace ''
|
|
|
|
|
|
|
|
refute @co.documented?
|
|
|
|
|
2010-12-19 22:22:49 -05:00
|
|
|
@co.document_self = nil # notify :nodoc:
|
2010-04-01 03:45:16 -04:00
|
|
|
|
|
|
|
assert @co.documented?
|
|
|
|
end
|
|
|
|
|
2010-12-19 22:22:49 -05:00
|
|
|
def test_done_documenting
|
|
|
|
# once done_documenting is set, other properties refuse to go to "true"
|
|
|
|
@co.done_documenting = true
|
|
|
|
|
|
|
|
@co.document_self = true
|
|
|
|
refute @co.document_self
|
|
|
|
|
|
|
|
@co.document_children = true
|
|
|
|
refute @co.document_children
|
|
|
|
|
|
|
|
@co.force_documentation = true
|
|
|
|
refute @co.force_documentation
|
|
|
|
|
|
|
|
@co.start_doc
|
|
|
|
refute @co.document_self
|
|
|
|
refute @co.document_children
|
|
|
|
|
|
|
|
# turning done_documenting on
|
|
|
|
# resets others to true
|
|
|
|
|
|
|
|
@co.done_documenting = false
|
|
|
|
assert @co.document_self
|
|
|
|
assert @co.document_children
|
2013-09-18 19:33:36 -04:00
|
|
|
|
|
|
|
@co.done_documenting = true
|
|
|
|
|
|
|
|
@store.rdoc.options.visibility = :nodoc
|
|
|
|
|
|
|
|
@co.store = @store
|
2013-09-19 03:22:13 -04:00
|
|
|
|
2013-09-18 19:33:36 -04:00
|
|
|
refute @co.done_documenting
|
|
|
|
|
|
|
|
@co.done_documenting = true
|
|
|
|
|
|
|
|
refute @co.done_documenting
|
2010-12-19 22:22:49 -05:00
|
|
|
end
|
|
|
|
|
2011-05-13 20:39:16 -04:00
|
|
|
def test_each_parent
|
|
|
|
parents = []
|
|
|
|
|
|
|
|
@parent_m.each_parent do |code_object|
|
|
|
|
parents << code_object
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal [@parent, @xref_data], parents
|
|
|
|
end
|
|
|
|
|
2011-06-16 00:59:24 -04:00
|
|
|
def test_file_name
|
|
|
|
assert_equal nil, @co.file_name
|
|
|
|
|
2012-11-26 23:28:14 -05:00
|
|
|
@co.record_location @store.add_file 'lib/file.rb'
|
2011-06-16 00:59:24 -04:00
|
|
|
|
|
|
|
assert_equal 'lib/file.rb', @co.file_name
|
|
|
|
end
|
|
|
|
|
2010-12-19 22:22:49 -05:00
|
|
|
def test_full_name_equals
|
|
|
|
@co.full_name = 'hi'
|
|
|
|
|
|
|
|
assert_equal 'hi', @co.instance_variable_get(:@full_name)
|
|
|
|
|
|
|
|
@co.full_name = nil
|
|
|
|
|
|
|
|
assert_nil @co.instance_variable_get(:@full_name)
|
|
|
|
end
|
|
|
|
|
2011-07-30 20:19:00 -04:00
|
|
|
def test_ignore
|
|
|
|
@co.ignore
|
|
|
|
|
|
|
|
refute @co.document_self
|
|
|
|
refute @co.document_children
|
|
|
|
assert @co.ignored?
|
2013-09-18 19:33:36 -04:00
|
|
|
|
|
|
|
@store.rdoc.options.visibility = :nodoc
|
|
|
|
|
|
|
|
@co.store = @store
|
|
|
|
|
|
|
|
assert @co.document_self
|
|
|
|
assert @co.document_children
|
|
|
|
refute @co.ignored?
|
|
|
|
|
|
|
|
@co.ignore
|
|
|
|
|
|
|
|
refute @co.ignored?
|
2011-07-30 20:19:00 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_ignore_eh
|
|
|
|
refute @co.ignored?
|
|
|
|
|
|
|
|
@co.ignore
|
|
|
|
|
|
|
|
assert @co.ignored?
|
|
|
|
end
|
|
|
|
|
2011-02-01 19:32:30 -05:00
|
|
|
def test_line
|
|
|
|
@c1_m.line = 5
|
|
|
|
|
|
|
|
assert_equal 5, @c1_m.line
|
|
|
|
end
|
|
|
|
|
2010-04-22 22:32:20 -04:00
|
|
|
def test_metadata
|
|
|
|
assert_empty @co.metadata
|
|
|
|
|
|
|
|
@co.metadata['markup'] = 'not_rdoc'
|
|
|
|
|
|
|
|
expected = { 'markup' => 'not_rdoc' }
|
|
|
|
|
|
|
|
assert_equal expected, @co.metadata
|
|
|
|
|
|
|
|
assert_equal 'not_rdoc', @co.metadata['markup']
|
|
|
|
end
|
|
|
|
|
2013-09-18 19:33:36 -04:00
|
|
|
def test_options
|
|
|
|
assert_kind_of RDoc::Options, @co.options
|
|
|
|
|
|
|
|
@co.store = @store
|
|
|
|
|
|
|
|
assert_same @options, @co.options
|
|
|
|
end
|
|
|
|
|
2010-04-01 03:45:16 -04:00
|
|
|
def test_parent_file_name
|
|
|
|
assert_equal '(unknown)', @co.parent_file_name
|
|
|
|
assert_equal 'xref_data.rb', @c1.parent_file_name
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_parent_name
|
|
|
|
assert_equal '(unknown)', @co.parent_name
|
|
|
|
assert_equal 'xref_data.rb', @c1.parent_name
|
|
|
|
assert_equal 'C2', @c2_c3.parent_name
|
|
|
|
end
|
|
|
|
|
2010-12-19 22:22:49 -05:00
|
|
|
def test_received_ndoc
|
|
|
|
@co.document_self = false
|
|
|
|
refute @co.received_nodoc
|
|
|
|
|
|
|
|
@co.document_self = nil
|
|
|
|
assert @co.received_nodoc
|
|
|
|
|
|
|
|
@co.document_self = true
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_record_location
|
2011-07-30 20:19:00 -04:00
|
|
|
@co.record_location @xref_data
|
2010-12-19 22:22:49 -05:00
|
|
|
|
2011-07-30 20:19:00 -04:00
|
|
|
assert_equal 'xref_data.rb', @co.file.relative_name
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_record_location_ignored
|
|
|
|
@co.ignore
|
|
|
|
@co.record_location @xref_data
|
|
|
|
|
|
|
|
refute @co.ignored?
|
2010-12-19 22:22:49 -05:00
|
|
|
end
|
|
|
|
|
2013-09-18 19:33:36 -04:00
|
|
|
def test_record_location_suppressed
|
|
|
|
@co.suppress
|
|
|
|
@co.record_location @xref_data
|
|
|
|
|
|
|
|
refute @co.suppressed?
|
|
|
|
end
|
|
|
|
|
2012-11-26 23:28:14 -05:00
|
|
|
def test_section
|
|
|
|
parent = RDoc::Context.new
|
|
|
|
section = parent.sections.first
|
|
|
|
|
|
|
|
@co.parent = parent
|
|
|
|
@co.instance_variable_set :@section, section
|
|
|
|
|
|
|
|
assert_equal section, @co.section
|
|
|
|
|
|
|
|
@co.instance_variable_set :@section, nil
|
|
|
|
@co.instance_variable_set :@section_title, nil
|
|
|
|
|
|
|
|
assert_equal section, @co.section
|
|
|
|
|
|
|
|
@co.instance_variable_set :@section, nil
|
|
|
|
@co.instance_variable_set :@section_title, 'new title'
|
|
|
|
|
|
|
|
assert_equal 'new title', @co.section.title
|
|
|
|
end
|
|
|
|
|
2010-04-01 03:45:16 -04:00
|
|
|
def test_start_doc
|
|
|
|
@co.document_self = false
|
|
|
|
@co.document_children = false
|
|
|
|
|
|
|
|
@co.start_doc
|
|
|
|
|
|
|
|
assert @co.document_self
|
|
|
|
assert @co.document_children
|
|
|
|
end
|
|
|
|
|
2011-07-30 20:19:00 -04:00
|
|
|
def test_start_doc_ignored
|
|
|
|
@co.ignore
|
|
|
|
|
|
|
|
@co.start_doc
|
|
|
|
|
|
|
|
assert @co.document_self
|
|
|
|
assert @co.document_children
|
|
|
|
refute @co.ignored?
|
|
|
|
end
|
|
|
|
|
2013-09-18 19:33:36 -04:00
|
|
|
def test_start_doc_suppressed
|
|
|
|
@co.suppress
|
|
|
|
|
|
|
|
@co.start_doc
|
|
|
|
|
|
|
|
assert @co.document_self
|
|
|
|
assert @co.document_children
|
|
|
|
refute @co.suppressed?
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_store_equals
|
|
|
|
@co.document_self = false
|
|
|
|
|
|
|
|
@co.store = @store
|
|
|
|
|
|
|
|
refute @co.document_self
|
|
|
|
|
|
|
|
@store.rdoc.options.visibility = :nodoc
|
|
|
|
|
|
|
|
@co.store = @store
|
|
|
|
|
|
|
|
assert @co.document_self
|
|
|
|
end
|
|
|
|
|
2010-04-01 03:45:16 -04:00
|
|
|
def test_stop_doc
|
|
|
|
@co.document_self = true
|
|
|
|
@co.document_children = true
|
|
|
|
|
|
|
|
@co.stop_doc
|
|
|
|
|
|
|
|
refute @co.document_self
|
|
|
|
refute @co.document_children
|
2013-09-18 19:33:36 -04:00
|
|
|
|
|
|
|
@store.rdoc.options.visibility = :nodoc
|
|
|
|
|
|
|
|
@co.store = @store
|
2013-09-19 03:22:13 -04:00
|
|
|
|
2013-09-18 19:33:36 -04:00
|
|
|
assert @co.document_self
|
|
|
|
assert @co.document_children
|
|
|
|
|
|
|
|
@co.stop_doc
|
|
|
|
|
|
|
|
assert @co.document_self
|
|
|
|
assert @co.document_children
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_suppress
|
|
|
|
@co.suppress
|
|
|
|
|
|
|
|
refute @co.document_self
|
|
|
|
refute @co.document_children
|
|
|
|
assert @co.suppressed?
|
|
|
|
|
|
|
|
@store.rdoc.options.visibility = :nodoc
|
|
|
|
|
|
|
|
@co.store = @store
|
2013-09-19 03:22:13 -04:00
|
|
|
|
2013-09-18 19:33:36 -04:00
|
|
|
refute @co.suppressed?
|
|
|
|
|
|
|
|
@co.suppress
|
|
|
|
|
|
|
|
refute @co.suppressed?
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_suppress_eh
|
|
|
|
refute @co.suppressed?
|
|
|
|
|
|
|
|
@co.suppress
|
|
|
|
|
|
|
|
assert @co.suppressed?
|
2010-04-01 03:45:16 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|