ruby/test/rdoc/test_rdoc_parser_changelog.rb

485 строки
14 KiB
Ruby

# frozen_string_literal: true
require_relative 'helper'
class TestRDocParserChangeLog < RDoc::TestCase
def setup
super
@tempfile = Tempfile.new 'ChangeLog'
@top_level = @store.add_file @tempfile.path
@options = RDoc::Options.new
@stats = RDoc::Stats.new @store, 0
end
def teardown
@tempfile.close!
super
end
def test_class_can_parse
parser = RDoc::Parser::ChangeLog
temp_dir do
FileUtils.touch 'ChangeLog'
assert_equal parser, parser.can_parse('ChangeLog')
assert_equal parser, parser.can_parse(@tempfile.path)
FileUtils.touch 'ChangeLog.rb'
assert_equal RDoc::Parser::Ruby, parser.can_parse('ChangeLog.rb')
end
end
def test_continue_entry_body
parser = util_parser
entry_body = ['a'.dup]
parser.continue_entry_body entry_body, 'b'
assert_equal ['a b'], entry_body
end
def test_continue_entry_body_empty
parser = util_parser
entry_body = []
parser.continue_entry_body entry_body, ''
assert_empty entry_body
end
def test_continue_entry_body_function
parser = util_parser
entry_body = ['file: (func1)'.dup]
parser.continue_entry_body entry_body, '(func2): blah'
assert_equal ['file: (func1, func2): blah'], entry_body
end
def test_create_document
parser = util_parser
groups = {
'2012-12-04' => [
['Tue Dec 4 08:33:46 2012 Eric Hodel <drbrain@segment7.net>',
%w[a:one b:two]],
['Tue Dec 4 08:32:10 2012 Eric Hodel <drbrain@segment7.net>',
%w[c:three d:four]]],
'2012-12-03' => [
['Mon Dec 3 20:28:02 2012 Koichi Sasada <ko1@atdot.net>',
%w[e:five f:six]]],
}
expected =
doc(
head(1, File.basename(@tempfile.path)),
blank_line,
head(2, '2012-12-04'),
blank_line,
head(3, 'Tue Dec 4 08:33:46 2012 Eric Hodel <drbrain@segment7.net>'),
blank_line,
list(:NOTE, item('a', para('one')), item('b', para('two'))),
head(3, 'Tue Dec 4 08:32:10 2012 Eric Hodel <drbrain@segment7.net>'),
blank_line,
list(:NOTE, item('c', para('three')), item('d', para('four'))),
head(2, '2012-12-03'),
blank_line,
head(3, 'Mon Dec 3 20:28:02 2012 Koichi Sasada <ko1@atdot.net>'),
blank_line,
list(:NOTE, item('e', para('five')), item('f', para('six'))))
expected.file = @top_level
document = parser.create_document(groups)
assert_equal expected, document
assert_equal 2, document.omit_headings_below
headings = document.parts.select do |part|
RDoc::Markup::Heading === part and part.level == 2
end
refute headings.all? { |heading| heading.text.frozen? }
end
def test_create_entries
parser = util_parser
entries = [
['Tue Dec 1 02:03:04 2012 Eric Hodel <drbrain@segment7.net>',
%w[a:one b:two]],
['Tue Dec 5 06:07:08 2012 Eric Hodel <drbrain@segment7.net>',
%w[c:three d:four]],
]
expected = [
head(3, 'Tue Dec 1 02:03:04 2012 Eric Hodel <drbrain@segment7.net>'),
blank_line,
list(:NOTE, item('a', para('one')), item('b', para('two'))),
head(3, 'Tue Dec 5 06:07:08 2012 Eric Hodel <drbrain@segment7.net>'),
blank_line,
list(:NOTE, item('c', para('three')), item('d', para('four'))),
]
entries = parser.create_entries(entries)
assert_equal expected, entries
end
def test_create_entries_colons
parser = util_parser
entries = [
['Wed Dec 5 12:17:11 2012 Naohisa Goto <ngotogenome@gmail.com>',
['func.rb (DL::Function#bind): log stuff [ruby-core:50562]']],
]
expected = [
head(3,
'Wed Dec 5 12:17:11 2012 Naohisa Goto <ngotogenome@gmail.com>'),
blank_line,
list(:NOTE,
item('func.rb (DL::Function#bind)',
para('log stuff [ruby-core:50562]')))]
assert_equal expected, parser.create_entries(entries)
end
def test_create_items
parser = util_parser
items = [
'README.EXT: Converted to RDoc format',
'README.EXT.ja: ditto',
]
expected =
list(:NOTE,
item('README.EXT',
para('Converted to RDoc format')),
item('README.EXT.ja',
para('ditto')))
assert_equal expected, parser.create_items(items)
end
def test_group_entries
parser = util_parser
entries = [
[ 'Tue Dec 4 08:33:46 2012 Eric Hodel <drbrain@segment7.net>',
%w[one two]],
[ 'Tue Dec 4 08:32:10 2012 Eric Hodel <drbrain@segment7.net>',
%w[three four]],
[ 'Mon Dec 3 20:28:02 2012 Koichi Sasada <ko1@atdot.net>',
%w[five six]],
[ '2008-01-30 H.J. Lu <hongjiu.lu@intel.com>',
%w[seven eight]]]
expected = {
'2012-12-04' => [
['Tue Dec 4 08:33:46 2012 Eric Hodel <drbrain@segment7.net>',
%w[one two]],
['Tue Dec 4 08:32:10 2012 Eric Hodel <drbrain@segment7.net>',
%w[three four]]],
'2012-12-03' => [
['Mon Dec 3 20:28:02 2012 Koichi Sasada <ko1@atdot.net>',
%w[five six]]],
'2008-01-30' => [
['2008-01-30 H.J. Lu <hongjiu.lu@intel.com>',
%w[seven eight]]],
}
assert_equal expected, parser.group_entries(entries)
end
def test_parse_entries
parser = util_parser <<-ChangeLog
Tue Dec 4 08:33:46 2012 Eric Hodel <drbrain@segment7.net>
* README.EXT: Converted to RDoc format
* README.EXT.ja: ditto
Mon Dec 3 20:28:02 2012 Koichi Sasada <ko1@atdot.net>
* compile.c (iseq_specialized_instruction):
change condition of using `opt_send_simple'.
More method invocations can be simple.
commit\ 8187228de0142d3ac7950b7d977c2849e934c637
Other note that will be ignored
ChangeLog
expected = [
[ 'Tue Dec 4 08:33:46 2012 Eric Hodel <drbrain@segment7.net>',
[ 'README.EXT: Converted to RDoc format',
'README.EXT.ja: ditto']],
[ 'Mon Dec 3 20:28:02 2012 Koichi Sasada <ko1@atdot.net>',
[ 'compile.c (iseq_specialized_instruction): change condition of ' +
'using `opt_send_simple\'. More method invocations can be simple.']]]
assert_equal expected, parser.parse_entries
end
def test_parse_entries_bad_time
parser = util_parser <<-ChangeLog
2008-01-30 H.J. Lu <hongjiu.lu@intel.com>
PR libffi/34612
* src/x86/sysv.S (ffi_closure_SYSV): Pop 4 byte from stack when
returning struct.
ChangeLog
expected = [
[ '2008-01-30 H.J. Lu <hongjiu.lu@intel.com>',
[ 'src/x86/sysv.S (ffi_closure_SYSV): Pop 4 byte from stack when ' +
'returning struct.']]
]
assert_equal expected, parser.parse_entries
end
def test_parse_entries_gnu
parser = util_parser <<-ChangeLog
1998-08-17 Richard Stallman <rms@gnu.org>
* register.el (insert-register): Return nil.
(jump-to-register): Likewise.
* sort.el (sort-subr): Return nil.
* keyboard.c (menu_bar_items, tool_bar_items)
(Fexecute_extended_command): Deal with 'keymap' property.
ChangeLog
expected = [
[ '1998-08-17 Richard Stallman <rms@gnu.org>',
[ 'register.el (insert-register): Return nil.',
'(jump-to-register): Likewise.',
'sort.el (sort-subr): Return nil.',
'keyboard.c (menu_bar_items, tool_bar_items, ' +
'Fexecute_extended_command): Deal with \'keymap\' property.']]]
assert_equal expected, parser.parse_entries
end
def test_parse_entries_git
parser = util_parser <<-ChangeLog
commit\ 709bed2afaee50e2ce803f87bf1ee8291bea41e3
Author: git <svn-admin@ruby-lang.org>
Date: 2021-01-21 01:03:52 +0900
* 2021-01-21 [ci skip]
ChangeLog
expected = [
[ "709bed2afaee50e2ce80",
[ "git", "svn-admin@ruby-lang.org",
"2021-01-21 01:03:52 +0900",
"* 2021-01-21 [ci skip]\n"]]]
assert_equal expected, parser.parse_entries
end
def test_scan
parser = util_parser <<-ChangeLog
Tue Dec 4 08:32:10 2012 Eric Hodel <drbrain@segment7.net>
* lib/rdoc/ri/driver.rb: Fixed ri page display for files with
extensions.
* test/rdoc/test_rdoc_ri_driver.rb: Test for above
Mon Dec 3 20:37:22 2012 Koichi Sasada <ko1@atdot.net>
* vm_exec.c: check VM_COLLECT_USAGE_DETAILS.
ChangeLog
parser.scan
expected = doc(
head(1, File.basename(@tempfile.path)),
blank_line,
head(2, '2012-12-04'),
blank_line,
head(3, 'Tue Dec 4 08:32:10 2012 Eric Hodel <drbrain@segment7.net>'),
blank_line,
list(:NOTE,
item('lib/rdoc/ri/driver.rb', para('Fixed ri page display for ' +
'files with extensions.')),
item('test/rdoc/test_rdoc_ri_driver.rb', para('Test for above'))),
head(2, '2012-12-03'),
blank_line,
head(3, 'Mon Dec 3 20:37:22 2012 Koichi Sasada <ko1@atdot.net>'),
blank_line,
list(:NOTE,
item('vm_exec.c', para('check VM_COLLECT_USAGE_DETAILS.'))))
expected.file = @top_level
assert_equal expected, @top_level.comment
end
def test_scan_git
parser = util_parser <<-ChangeLog
commit\ 38816887962ec167ee46acf500f68df5c3013163
Author: git <svn-admin@ruby-lang.org>
Date: Sun Jan 24 14:35:51 2021 +0900
* 2021-01-24 [ci skip]
commit\ db7d0b89f6eca66cc7eb155c95f9123133da1ffc
Author: git <svn-admin@ruby-lang.org>
Date: Sat, 23 Jan 2021 06:01:39 +0900
* 2021-01-23 [ci skip]
commit\ a3efbda7128ef20b55505b32d1608ea48f80af4a
Author: git <svn-admin@ruby-lang.org>
Date: 2021-01-22T02:49:39+09:00
* 2021-01-22 [ci skip]
commit\ 709bed2afaee50e2ce803f87bf1ee8291bea41e3
Author: git <svn-admin@ruby-lang.org>
Date: 2021-01-21 01:03:52 +0900
* 2021-01-21 [ci skip]
commit\ a8dc5156e183489c5121fb1759bda5d9406d9175
Author: git <svn-admin@ruby-lang.org>
Date: 2021-01-20 01:58:26 +0900
* 2021-01-20 [ci skip]
commit\ de5f8a92d5001799bedb3b1a271a2d9b23c6c8fb
Author: Masataka Pocke Kuwabara <kuwabara@pocke.me>
Date: 2021-01-01 14:25:08 +0900
Make args info for RubyVM::AST to available on endless method without parens
Problem
===
Arguments information is missing for endless method without parens.
For example:
```ruby
# ok
```
It causes an error if a program expects `args` node exists.
Solution
===
Call `new_args` on this case.
ChangeLog
parser.scan
expected = doc(
head(1, File.basename(@tempfile.path)),
blank_line,
head(2, '2021-01-24'),
blank_line,
log_entry(nil, '38816887962ec167ee46',
'git', 'svn-admin@ruby-lang.org', 'Sun Jan 24 14:35:51 2021 +0900',
[list(:BULLET, item(nil, para('2021-01-24 [ci skip]')))]),
head(2, '2021-01-23'),
blank_line,
log_entry(nil, 'db7d0b89f6eca66cc7eb',
'git', 'svn-admin@ruby-lang.org', 'Sat, 23 Jan 2021 06:01:39 +0900',
[list(:BULLET, item(nil, para('2021-01-23 [ci skip]')))]),
head(2, '2021-01-22'),
blank_line,
log_entry(nil, 'a3efbda7128ef20b5550',
'git', 'svn-admin@ruby-lang.org', '2021-01-22T02:49:39+09:00',
[list(:BULLET, item(nil, para('2021-01-22 [ci skip]')))]),
head(2, '2021-01-21'),
blank_line,
log_entry(nil, '709bed2afaee50e2ce80',
'git', 'svn-admin@ruby-lang.org', '2021-01-21 01:03:52 +0900',
[list(:BULLET, item(nil, para('2021-01-21 [ci skip]')))]),
head(2, '2021-01-20'),
blank_line,
log_entry(nil, 'a8dc5156e183489c5121',
'git', 'svn-admin@ruby-lang.org', '2021-01-20 01:58:26 +0900',
[list(:BULLET, item(nil, para('2021-01-20 [ci skip]')))]),
head(2, '2021-01-01'),
blank_line,
log_entry(nil, 'de5f8a92d5001799bedb',
'Masataka Pocke Kuwabara', 'kuwabara@pocke.me', '2021-01-01 14:25:08 +0900',
[head(4, 'Make args info for RubyVM::AST to available on endless method without parens'),
head(5, 'Problem'),
para("Arguments information is missing for endless method without parens.\n" +
"For example:"),
verb("# ok\n").tap {|v| v.format = :ruby},
para('It causes an error if a program expects <code>args</code> node exists.'),
head(5, 'Solution'),
para('Call <code>new_args</code> on this case.')]))
expected.file = @top_level
assert_equal expected, @top_level.comment
end
def test_scan_git_commit_date
parser = util_parser <<-ChangeLog
commit\ ee1e690a2df901adb279d7a63fbd92c64e0a5ae6
Author: Igor Zubkov <igor.zubkov@gmail.com>
AuthorDate: 2016-10-25 03:56:11 +0900
Commit: Nobuyoshi Nakada <nobu@ruby-lang.org>
CommitDate: 2021-01-07 13:40:42 +0900
We don't need "require 'uri'" after "require 'net/http'".
commit\ 4d0985a7bd8f591dff4b430e288bfd83af782e51
Author: git <svn-admin@ruby-lang.org>
AuthorDate: 2021-01-07 10:21:34 +0900
Commit: git <svn-admin@ruby-lang.org>
CommitDate: 2021-01-07 10:21:34 +0900
* 2021-01-07 [ci skip]
ChangeLog
parser.scan
expected = doc(
head(1, File.basename(@tempfile.path)),
blank_line,
head(2, "2021-01-07"),
blank_line,
log_entry(nil, 'ee1e690a2df901adb279',
'Igor Zubkov', 'igor.zubkov@gmail.com',
'2016-10-25 03:56:11 +0900',
[head(4, %[We don't need "require 'uri'" after "require 'net/http'".])]),
log_entry(nil, '4d0985a7bd8f591dff4b',
'git', 'svn-admin@ruby-lang.org',
'2021-01-07 10:21:34 +0900',
[list(:BULLET, item(nil, para("2021-01-07 [ci skip]")))]))
expected.file = @top_level
assert_equal expected, @top_level.comment
end
def util_parser content = ''
RDoc::Parser::ChangeLog.new \
@top_level, @tempfile.path, content, @options, @stats
end
def log_entry(*a)
RDoc::Parser::ChangeLog::Git::LogEntry.new(*a)
end
end