review 4.1.0 → 5.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/workflows/ruby-tex.yml +35 -0
- data/.github/workflows/ruby-win.yml +19 -9
- data/.github/workflows/ruby.yml +7 -3
- data/.rubocop.yml +138 -34
- data/NEWS.ja.md +285 -0
- data/NEWS.md +285 -1
- data/README.md +7 -6
- data/Rakefile +7 -2
- data/bin/review +2 -4
- data/bin/review-catalog-converter +4 -4
- data/bin/review-check +8 -12
- data/bin/review-checkdep +2 -5
- data/bin/review-compile +18 -34
- data/bin/review-epub2html +1 -4
- data/bin/review-epubmaker +3 -4
- data/bin/review-idgxmlmaker +1 -3
- data/bin/review-index +5 -86
- data/bin/review-init +1 -4
- data/bin/review-pdfmaker +1 -3
- data/bin/review-preproc +30 -38
- data/bin/review-textmaker +1 -3
- data/bin/review-update +1 -4
- data/bin/review-validate +4 -4
- data/bin/review-vol +5 -82
- data/bin/review-webmaker +1 -3
- data/doc/config.yml.sample +45 -11
- data/doc/config.yml.sample-simple +3 -3
- data/doc/format.ja.md +103 -13
- data/doc/format.md +104 -16
- data/doc/makeindex.ja.md +2 -2
- data/doc/pdfmaker.ja.md +42 -0
- data/doc/pdfmaker.md +41 -0
- data/doc/quickstart.ja.md +19 -6
- data/doc/quickstart.md +18 -6
- data/doc/writing_vertical.ja.md +6 -0
- data/lib/review.rb +1 -1
- data/lib/review/book.rb +2 -2
- data/lib/review/book/base.rb +67 -29
- data/lib/review/book/bib.rb +21 -0
- data/lib/review/book/book_unit.rb +158 -0
- data/lib/review/book/chapter.rb +33 -26
- data/lib/review/book/index.rb +24 -185
- data/lib/review/book/index/item.rb +7 -1
- data/lib/review/book/page_metric.rb +7 -7
- data/lib/review/book/part.rb +26 -11
- data/lib/review/book/volume.rb +5 -5
- data/lib/review/builder.rb +121 -52
- data/lib/review/call_hook.rb +20 -0
- data/lib/review/catalog.rb +3 -2
- data/lib/review/compiler.rb +230 -111
- data/lib/review/configure.rb +91 -7
- data/lib/review/converter.rb +1 -1
- data/lib/review/epub2html.rb +6 -1
- data/lib/review/epubmaker.rb +124 -152
- data/lib/review/epubmaker/content.rb +113 -0
- data/lib/review/epubmaker/epubcommon.rb +372 -0
- data/lib/review/epubmaker/epubv2.rb +178 -0
- data/lib/review/epubmaker/epubv3.rb +231 -0
- data/lib/review/epubmaker/producer.rb +167 -0
- data/lib/review/epubmaker/reviewheaderlistener.rb +12 -2
- data/lib/review/epubmaker/zip_exporter.rb +84 -0
- data/lib/review/exception.rb +13 -0
- data/lib/review/htmlbuilder.rb +176 -89
- data/lib/review/htmlutils.rb +8 -11
- data/lib/review/i18n.rb +2 -1
- data/lib/review/idgxmlbuilder.rb +165 -75
- data/lib/review/idgxmlmaker.rb +24 -28
- data/lib/review/img_math.rb +238 -0
- data/lib/review/index_builder.rb +645 -0
- data/lib/review/init.rb +9 -17
- data/lib/review/latexbox.rb +58 -0
- data/lib/review/latexbuilder.rb +193 -75
- data/lib/review/latexutils.rb +9 -1
- data/lib/review/lineinput.rb +112 -2
- data/lib/review/loggable.rb +27 -0
- data/lib/review/logger.rb +90 -3
- data/lib/review/makerhelper.rb +17 -188
- data/lib/review/markdownbuilder.rb +54 -4
- data/lib/review/pdfmaker.rb +76 -84
- data/lib/review/plaintextbuilder.rb +106 -22
- data/lib/review/preprocessor.rb +107 -303
- data/lib/review/preprocessor/directive.rb +35 -0
- data/lib/review/preprocessor/line.rb +34 -0
- data/lib/review/preprocessor/repository.rb +177 -0
- data/lib/review/rstbuilder.rb +27 -8
- data/lib/review/sec_counter.rb +14 -0
- data/lib/review/template.rb +11 -1
- data/lib/review/textmaker.rb +27 -32
- data/lib/review/textutils.rb +3 -12
- data/lib/review/tocprinter.rb +242 -97
- data/lib/review/topbuilder.rb +98 -31
- data/lib/review/update.rb +12 -13
- data/lib/review/version.rb +1 -1
- data/lib/review/volumeprinter.rb +97 -0
- data/lib/review/webmaker.rb +40 -47
- data/lib/review/webtocprinter.rb +39 -35
- data/lib/review/yamlloader.rb +2 -1
- data/review.gemspec +5 -3
- data/samples/sample-book/src/config-epub2.yml +1 -1
- data/samples/sample-book/src/config.yml +3 -3
- data/samples/sample-book/src/lib/tasks/review.rake +19 -1
- data/samples/sample-book/src/lib/tasks/z01_copy_sty.rake +2 -1
- data/samples/syntax-book/Gemfile +1 -1
- data/samples/syntax-book/ch01.re +1 -1
- data/samples/syntax-book/ch02.re +21 -6
- data/samples/syntax-book/ch03.re +1 -1
- data/samples/syntax-book/config.yml +1 -1
- data/samples/syntax-book/images/img3-2.png +0 -0
- data/samples/syntax-book/lib/tasks/z01_copy_sty.rake +2 -1
- data/templates/html/_colophon.html.erb +23 -0
- data/templates/html/_colophon_history.html.erb +9 -0
- data/templates/html/_cover.html.erb +10 -0
- data/templates/html/_part_body.html.erb +6 -0
- data/templates/html/_titlepage.html.erb +20 -0
- data/templates/html/layout-html5.html.erb +6 -0
- data/templates/html/layout-xhtml1.html.erb +6 -0
- data/templates/latex/config.erb +35 -23
- data/templates/latex/review-jlreq/README.md +3 -1
- data/templates/latex/review-jlreq/review-base.sty +36 -23
- data/templates/latex/review-jlreq/review-jlreq.cls +18 -25
- data/templates/latex/review-jlreq/review-style.sty +6 -1
- data/templates/latex/review-jlreq/review-tcbox.sty +348 -0
- data/templates/latex/review-jlreq/reviewmacro.sty +5 -0
- data/templates/latex/review-jsbook/README.md +7 -5
- data/templates/latex/review-jsbook/review-base.sty +40 -24
- data/templates/latex/review-jsbook/review-jsbook.cls +13 -3
- data/templates/latex/review-jsbook/review-style.sty +6 -1
- data/templates/latex/review-jsbook/review-tcbox.sty +348 -0
- data/templates/latex/review-jsbook/reviewmacro.sty +5 -0
- data/templates/opf/epubv2.opf.erb +7 -7
- data/templates/opf/epubv3.opf.erb +7 -7
- data/templates/opf/opf_manifest_epubv2.opf.erb +10 -0
- data/templates/opf/opf_manifest_epubv3.opf.erb +10 -0
- data/templates/opf/opf_metainfo_epubv2.opf.erb +17 -0
- data/templates/opf/opf_metainfo_epubv3.opf.erb +49 -0
- data/templates/opf/opf_tocx_epubv2.opf.erb +9 -0
- data/templates/opf/opf_tocx_epubv3.opf.erb +17 -0
- data/templates/web/html/layout-html5.html.erb +9 -8
- data/templates/web/html/layout-xhtml1.html.erb +6 -0
- data/test/assets/header_listener.html +35 -0
- data/test/assets/img_math/img1.png +0 -0
- data/test/assets/img_math/img2.png +0 -0
- data/test/assets/img_math/img3.png +0 -0
- data/test/assets/syntax_book_index_detail.txt +58 -0
- data/test/assets/test_template.tex +6 -3
- data/test/assets/test_template_backmatter.tex +6 -3
- data/test/book_test_helper.rb +11 -5
- data/test/run_test.rb +1 -1
- data/test/test_book.rb +54 -63
- data/test/test_book_chapter.rb +95 -54
- data/test/test_book_part.rb +3 -3
- data/test/test_builder.rb +29 -20
- data/test/test_catalog_converter_cmd.rb +1 -1
- data/test/test_converter.rb +1 -0
- data/test/test_epub3maker.rb +170 -126
- data/test/test_epubmaker.rb +254 -129
- data/test/test_epubmaker_cmd.rb +15 -4
- data/test/test_helper.rb +12 -5
- data/test/test_htmlbuilder.rb +926 -76
- data/test/test_htmlutils.rb +0 -12
- data/test/test_i18n.rb +33 -33
- data/test/test_idgxmlbuilder.rb +531 -20
- data/test/test_idgxmlmaker_cmd.rb +7 -3
- data/test/test_img_math.rb +111 -0
- data/test/test_index.rb +62 -52
- data/test/test_indexbuilder.rb +52 -0
- data/test/test_latexbuilder.rb +891 -20
- data/test/test_latexbuilder_v2.rb +56 -10
- data/test/test_lineinput.rb +20 -93
- data/test/test_logger.rb +7 -7
- data/test/test_makerhelper.rb +0 -12
- data/test/test_markdownbuilder.rb +32 -0
- data/test/test_pdfmaker.rb +100 -11
- data/test/test_pdfmaker_cmd.rb +3 -3
- data/test/test_plaintextbuilder.rb +546 -32
- data/test/test_preprocessor.rb +188 -1
- data/test/test_review_ext.rb +2 -1
- data/test/test_reviewheaderlistener.rb +49 -0
- data/test/test_rstbuilder.rb +25 -1
- data/test/test_sec_counter.rb +156 -0
- data/test/test_template.rb +12 -2
- data/test/test_textmaker_cmd.rb +5 -1
- data/test/test_tocprinter.rb +46 -0
- data/test/test_topbuilder.rb +324 -20
- data/test/test_update.rb +44 -44
- data/test/test_webtocprinter.rb +75 -43
- data/test/test_zip_exporter.rb +5 -6
- data/vendor/gentombow/LICENSE +1 -1
- data/vendor/gentombow/Makefile +0 -1
- data/vendor/gentombow/bounddvi-en.pdf +0 -0
- data/vendor/gentombow/bounddvi-en.tex +1 -0
- data/vendor/gentombow/bounddvi.pdf +0 -0
- data/vendor/gentombow/bounddvi.sty +30 -7
- data/vendor/gentombow/bounddvi.tex +1 -0
- data/vendor/gentombow/create_archive.sh +1 -0
- data/vendor/gentombow/gentombow-ja.pdf +0 -0
- data/vendor/gentombow/gentombow-ja.tex +9 -0
- data/vendor/gentombow/gentombow.pdf +0 -0
- data/vendor/gentombow/gentombow.sty +32 -10
- data/vendor/gentombow/gentombow.tex +8 -0
- data/vendor/gentombow/tests/gentombow-01-pdfx.tex +8 -0
- data/vendor/gentombow/tests/gentombow-02-pdfx.tex +8 -0
- data/vendor/jsclasses/Makefile +3 -2
- data/vendor/jsclasses/create_archive.sh +5 -5
- data/vendor/jsclasses/jis/Makefile +3 -2
- data/vendor/jsclasses/jis/jsarticle.cls +22 -18
- data/vendor/jsclasses/jis/jsbook.cls +22 -18
- data/vendor/jsclasses/jis/jsclasses.dtx +94 -13
- data/vendor/jsclasses/jis/jsclasses.ins +15 -5
- data/vendor/jsclasses/jis/jslogo.ins +9 -0
- data/vendor/jsclasses/jis/jslogo.sty +1 -13
- data/vendor/jsclasses/jis/jspf.cls +22 -18
- data/vendor/jsclasses/jis/jsreport.cls +22 -18
- data/vendor/jsclasses/jis/jsverb.ins +9 -0
- data/vendor/jsclasses/jis/jsverb.sty +1 -13
- data/vendor/jsclasses/jis/kiyou.cls +22 -18
- data/vendor/jsclasses/jis/minijs.sty +65 -22
- data/vendor/jsclasses/jis/okumacro.ins +9 -0
- data/vendor/jsclasses/jis/okumacro.sty +1 -13
- data/vendor/jsclasses/jis/okuverb.ins +9 -0
- data/vendor/jsclasses/jis/okuverb.sty +1 -13
- data/vendor/jsclasses/jis/winjis.sty +23 -19
- data/vendor/jsclasses/jsarticle.cls +22 -18
- data/vendor/jsclasses/jsbook.cls +22 -18
- data/vendor/jsclasses/jsclasses.dtx +94 -13
- data/vendor/jsclasses/jsclasses.ins +15 -5
- data/vendor/jsclasses/jsclasses.pdf +0 -0
- data/vendor/jsclasses/jslogo.ins +9 -0
- data/vendor/jsclasses/jslogo.pdf +0 -0
- data/vendor/jsclasses/jslogo.sty +1 -13
- data/vendor/jsclasses/jspf.cls +22 -18
- data/vendor/jsclasses/jsreport.cls +22 -18
- data/vendor/jsclasses/jsverb.ins +9 -0
- data/vendor/jsclasses/jsverb.pdf +0 -0
- data/vendor/jsclasses/jsverb.sty +1 -13
- data/vendor/jsclasses/kiyou.cls +22 -18
- data/vendor/jsclasses/minijs.sty +68 -22
- data/vendor/jsclasses/okumacro.ins +9 -0
- data/vendor/jsclasses/okumacro.pdf +0 -0
- data/vendor/jsclasses/okumacro.sty +1 -13
- data/vendor/jsclasses/okuverb.ins +9 -0
- data/vendor/jsclasses/okuverb.pdf +0 -0
- data/vendor/jsclasses/okuverb.sty +1 -13
- data/vendor/jsclasses/tests/relfont.tex +10 -0
- data/vendor/jsclasses/winjis.sty +23 -19
- metadata +106 -22
- data/.rubocop_todo.yml +0 -7
- data/lib/epubmaker.rb +0 -23
- data/lib/epubmaker/content.rb +0 -110
- data/lib/epubmaker/epubcommon.rb +0 -441
- data/lib/epubmaker/epubv2.rb +0 -143
- data/lib/epubmaker/epubv3.rb +0 -233
- data/lib/epubmaker/producer.rb +0 -375
- data/lib/epubmaker/zip_exporter.rb +0 -81
- data/lib/lineinput.rb +0 -155
- data/lib/review/book/compilable.rb +0 -178
- data/lib/review/tocparser.rb +0 -275
- data/test/test_tocparser.rb +0 -25
data/test/test_epubmaker.rb
CHANGED
@@ -1,12 +1,10 @@
|
|
1
1
|
require 'test_helper'
|
2
|
-
require 'epubmaker'
|
2
|
+
require 'review/epubmaker'
|
3
3
|
|
4
4
|
class EPUBMakerTest < Test::Unit::TestCase
|
5
|
-
include EPUBMaker
|
6
|
-
|
7
5
|
def setup
|
8
|
-
|
9
|
-
|
6
|
+
config = ReVIEW::Configure.values
|
7
|
+
config.merge!(
|
10
8
|
'bookname' => 'sample',
|
11
9
|
'title' => 'Sample Book',
|
12
10
|
'epubversion' => 2,
|
@@ -15,30 +13,34 @@ class EPUBMakerTest < Test::Unit::TestCase
|
|
15
13
|
'language' => 'en',
|
16
14
|
'titlepage' => nil
|
17
15
|
)
|
18
|
-
@
|
16
|
+
@log_io = StringIO.new
|
17
|
+
ReVIEW.logger = ReVIEW::Logger.new(@log_io)
|
18
|
+
@producer = ReVIEW::EPUBMaker::Producer.new(config)
|
19
19
|
end
|
20
20
|
|
21
21
|
def test_initialize
|
22
|
-
assert Producer.new
|
22
|
+
assert ReVIEW::EPUBMaker::Producer.new(ReVIEW::Configure.values)
|
23
23
|
end
|
24
24
|
|
25
25
|
def test_resource_en
|
26
|
-
@producer.
|
27
|
-
|
26
|
+
@producer.config['language'] = 'en'
|
27
|
+
@producer.modify_config
|
28
|
+
assert_equal 'Table of Contents', ReVIEW::I18n.t('toctitle')
|
28
29
|
end
|
29
30
|
|
30
31
|
def test_resource_ja
|
31
|
-
@producer.
|
32
|
-
|
32
|
+
@producer.config['language'] = 'ja'
|
33
|
+
@producer.modify_config
|
34
|
+
assert_equal '目次', ReVIEW::I18n.t('toctitle')
|
33
35
|
end
|
34
36
|
|
35
37
|
def test_mimetype
|
36
|
-
@producer.mimetype
|
37
|
-
assert_equal 'application/epub+zip',
|
38
|
+
output = @producer.instance_eval { @epub.mimetype }
|
39
|
+
assert_equal 'application/epub+zip', output
|
38
40
|
end
|
39
41
|
|
40
42
|
def test_container
|
41
|
-
@producer.container
|
43
|
+
output = @producer.instance_eval { @epub.container }
|
42
44
|
expect = <<EOT
|
43
45
|
<?xml version="1.0" encoding="UTF-8"?>
|
44
46
|
<container xmlns="urn:oasis:names:tc:opendocument:xmlns:container" version="1.0">
|
@@ -47,11 +49,11 @@ class EPUBMakerTest < Test::Unit::TestCase
|
|
47
49
|
</rootfiles>
|
48
50
|
</container>
|
49
51
|
EOT
|
50
|
-
assert_equal expect,
|
52
|
+
assert_equal expect, output
|
51
53
|
end
|
52
54
|
|
53
55
|
def test_stage1_opf
|
54
|
-
@producer.opf
|
56
|
+
output = @producer.instance_eval { @epub.opf }
|
55
57
|
expect = <<EOT
|
56
58
|
<?xml version="1.0" encoding="UTF-8"?>
|
57
59
|
<package version="2.0" xmlns="http://www.idpf.org/2007/opf" unique-identifier="BookId">
|
@@ -73,12 +75,13 @@ EOT
|
|
73
75
|
</guide>
|
74
76
|
</package>
|
75
77
|
EOT
|
76
|
-
assert_equal expect,
|
78
|
+
assert_equal expect, output
|
77
79
|
end
|
78
80
|
|
79
81
|
def test_stage1_opf_escape
|
80
82
|
@producer.config['title'] = 'Sample<>Book'
|
81
|
-
@producer.
|
83
|
+
@producer.modify_config
|
84
|
+
output = @producer.instance_eval { @epub.opf }
|
82
85
|
expect = <<EOT
|
83
86
|
<?xml version="1.0" encoding="UTF-8"?>
|
84
87
|
<package version="2.0" xmlns="http://www.idpf.org/2007/opf" unique-identifier="BookId">
|
@@ -100,11 +103,11 @@ EOT
|
|
100
103
|
</guide>
|
101
104
|
</package>
|
102
105
|
EOT
|
103
|
-
assert_equal expect,
|
106
|
+
assert_equal expect, output
|
104
107
|
end
|
105
108
|
|
106
109
|
def test_stage1_ncx
|
107
|
-
@producer.ncx(
|
110
|
+
output = @producer.instance_eval { @epub.ncx([]) }
|
108
111
|
expect = <<EOT
|
109
112
|
<?xml version="1.0" encoding="UTF-8"?>
|
110
113
|
<ncx xmlns="http://www.daisy.org/z3986/2005/ncx/" version="2005-1">
|
@@ -130,12 +133,13 @@ EOT
|
|
130
133
|
</navMap>
|
131
134
|
</ncx>
|
132
135
|
EOT
|
133
|
-
assert_equal expect,
|
136
|
+
assert_equal expect, output
|
134
137
|
end
|
135
138
|
|
136
139
|
def test_stage1_ncx_escape
|
137
140
|
@producer.config['title'] = 'Sample<>Book'
|
138
|
-
@producer.
|
141
|
+
@producer.modify_config
|
142
|
+
output = @producer.instance_eval { @epub.ncx([]) }
|
139
143
|
expect = <<EOT
|
140
144
|
<?xml version="1.0" encoding="UTF-8"?>
|
141
145
|
<ncx xmlns="http://www.daisy.org/z3986/2005/ncx/" version="2005-1">
|
@@ -161,27 +165,27 @@ EOT
|
|
161
165
|
</navMap>
|
162
166
|
</ncx>
|
163
167
|
EOT
|
164
|
-
assert_equal expect,
|
168
|
+
assert_equal expect, output
|
165
169
|
end
|
166
170
|
|
167
171
|
def stage2
|
168
172
|
# add one item
|
169
|
-
@producer.contents << Content.new(
|
173
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch01.html', title: 'CH01', level: 1)
|
170
174
|
end
|
171
175
|
|
172
176
|
def test_stage2_add_l1item
|
173
177
|
stage2
|
174
|
-
expect = EPUBMaker::Content.new('ch01.html',
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
178
|
+
expect = ReVIEW::EPUBMaker::Content.new(file: 'ch01.html',
|
179
|
+
id: 'ch01-html',
|
180
|
+
media: 'application/xhtml+xml',
|
181
|
+
title: 'CH01',
|
182
|
+
level: 1)
|
179
183
|
assert_equal expect, @producer.contents[0]
|
180
184
|
end
|
181
185
|
|
182
186
|
def test_stage2_opf
|
183
187
|
stage2
|
184
|
-
@producer.opf
|
188
|
+
output = @producer.instance_eval { @epub.opf }
|
185
189
|
expect = <<EOT
|
186
190
|
<?xml version="1.0" encoding="UTF-8"?>
|
187
191
|
<package version="2.0" xmlns="http://www.idpf.org/2007/opf" unique-identifier="BookId">
|
@@ -205,12 +209,12 @@ EOT
|
|
205
209
|
</guide>
|
206
210
|
</package>
|
207
211
|
EOT
|
208
|
-
assert_equal expect,
|
212
|
+
assert_equal expect, output
|
209
213
|
end
|
210
214
|
|
211
215
|
def test_stage2_ncx
|
212
216
|
stage2
|
213
|
-
@producer.ncx(
|
217
|
+
output = @producer.instance_eval { @epub.ncx([]) }
|
214
218
|
expect = <<EOT
|
215
219
|
<?xml version="1.0" encoding="UTF-8"?>
|
216
220
|
<ncx xmlns="http://www.daisy.org/z3986/2005/ncx/" version="2005-1">
|
@@ -242,54 +246,54 @@ EOT
|
|
242
246
|
</navMap>
|
243
247
|
</ncx>
|
244
248
|
EOT
|
245
|
-
assert_equal expect,
|
249
|
+
assert_equal expect, output
|
246
250
|
end
|
247
251
|
|
248
252
|
def stage3
|
249
253
|
# add more items
|
250
|
-
@producer.contents << Content.new(
|
251
|
-
@producer.contents << Content.new(
|
252
|
-
@producer.contents << Content.new(
|
253
|
-
@producer.contents << Content.new(
|
254
|
-
@producer.contents << Content.new(
|
255
|
-
@producer.contents << Content.new(
|
256
|
-
@producer.contents << Content.new(
|
257
|
-
@producer.contents << Content.new(
|
258
|
-
@producer.contents << Content.new(
|
259
|
-
@producer.contents << Content.new(
|
260
|
-
@producer.contents << Content.new(
|
261
|
-
@producer.contents << Content.new(
|
262
|
-
@producer.contents << Content.new(
|
263
|
-
@producer.contents << Content.new(
|
264
|
-
@producer.contents << Content.new(
|
265
|
-
@producer.contents << Content.new(
|
266
|
-
@producer.contents << Content.new(
|
267
|
-
@producer.contents << Content.new(
|
268
|
-
@producer.contents << Content.new(
|
254
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch01.html', title: %Q(CH01<>&"), level: 1)
|
255
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch02.html', title: 'CH02', level: 1)
|
256
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S1', title: 'CH02.1', level: 2)
|
257
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S1.1', title: 'CH02.1.1', level: 3)
|
258
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S1.1.1', title: 'CH02.1.1.1', level: 4)
|
259
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S1.1.1.1', title: 'CH02.1.1.1.1', level: 5)
|
260
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S1.1.2', title: 'CH02.1.1.2', level: 4)
|
261
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S2', title: 'CH02.2', level: 2)
|
262
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S2.1', title: 'CH02.2.1', level: 3)
|
263
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch03.html', title: 'CH03', level: 1)
|
264
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch03.html#S1', title: 'CH03.1', level: 2)
|
265
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch03.html#S1.1', title: 'CH03.1.1', level: 3)
|
266
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'ch04.html', title: 'CH04', level: 1)
|
267
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'sample.png')
|
268
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'sample.jpg')
|
269
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'sample.JPEG')
|
270
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'sample.SvG')
|
271
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'sample.GIF')
|
272
|
+
@producer.contents << ReVIEW::EPUBMaker::Content.new(file: 'sample.css')
|
269
273
|
end
|
270
274
|
|
271
275
|
def test_stage3_add_various_items
|
272
276
|
stage3
|
273
277
|
expect = [
|
274
|
-
Content.new('ch01.html', 'ch01-html', 'application/xhtml+xml', %Q(CH01<>&"), 1),
|
275
|
-
Content.new('ch02.html', 'ch02-html', 'application/xhtml+xml', 'CH02', 1),
|
276
|
-
Content.new('ch02.html#S1', 'ch02-html#S1', 'html#s1', 'CH02.1', 2),
|
277
|
-
Content.new('ch02.html#S1.1', 'ch02-html#S1-1', '1', 'CH02.1.1', 3),
|
278
|
-
Content.new('ch02.html#S1.1.1', 'ch02-html#S1-1-1', '1', 'CH02.1.1.1', 4),
|
279
|
-
Content.new('ch02.html#S1.1.1.1', 'ch02-html#S1-1-1-1', '1', 'CH02.1.1.1.1', 5),
|
280
|
-
Content.new('ch02.html#S1.1.2', 'ch02-html#S1-1-2', '2', 'CH02.1.1.2', 4),
|
281
|
-
Content.new('ch02.html#S2', 'ch02-html#S2', 'html#s2', 'CH02.2', 2),
|
282
|
-
Content.new('ch02.html#S2.1', 'ch02-html#S2-1', '1', 'CH02.2.1', 3),
|
283
|
-
Content.new('ch03.html', 'ch03-html', 'application/xhtml+xml', 'CH03', 1),
|
284
|
-
Content.new('ch03.html#S1', 'ch03-html#S1', 'html#s1', 'CH03.1', 2),
|
285
|
-
Content.new('ch03.html#S1.1', 'ch03-html#S1-1', '1', 'CH03.1.1', 3),
|
286
|
-
Content.new('ch04.html', 'ch04-html', 'application/xhtml+xml', 'CH04', 1),
|
287
|
-
Content.new('sample.png', 'sample-png', 'image/png'),
|
288
|
-
Content.new('sample.jpg', 'sample-jpg', 'image/jpeg'),
|
289
|
-
Content.new('sample.JPEG', 'sample-JPEG', 'image/jpeg'),
|
290
|
-
Content.new('sample.SvG', 'sample-SvG', 'image/svg+xml'),
|
291
|
-
Content.new('sample.GIF', 'sample-GIF', 'image/gif'),
|
292
|
-
Content.new('sample.css', 'sample-css', 'text/css')
|
278
|
+
ReVIEW::EPUBMaker::Content.new(file: 'ch01.html', id: 'ch01-html', media: 'application/xhtml+xml', title: %Q(CH01<>&"), level: 1),
|
279
|
+
ReVIEW::EPUBMaker::Content.new(file: 'ch02.html', id: 'ch02-html', media: 'application/xhtml+xml', title: 'CH02', level: 1),
|
280
|
+
ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S1', id: 'ch02-html#S1', media: 'html#s1', title: 'CH02.1', level: 2),
|
281
|
+
ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S1.1', id: 'ch02-html#S1-1', media: '1', title: 'CH02.1.1', level: 3),
|
282
|
+
ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S1.1.1', id: 'ch02-html#S1-1-1', media: '1', title: 'CH02.1.1.1', level: 4),
|
283
|
+
ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S1.1.1.1', id: 'ch02-html#S1-1-1-1', media: '1', title: 'CH02.1.1.1.1', level: 5),
|
284
|
+
ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S1.1.2', id: 'ch02-html#S1-1-2', media: '2', title: 'CH02.1.1.2', level: 4),
|
285
|
+
ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S2', id: 'ch02-html#S2', media: 'html#s2', title: 'CH02.2', level: 2),
|
286
|
+
ReVIEW::EPUBMaker::Content.new(file: 'ch02.html#S2.1', id: 'ch02-html#S2-1', media: '1', title: 'CH02.2.1', level: 3),
|
287
|
+
ReVIEW::EPUBMaker::Content.new(file: 'ch03.html', id: 'ch03-html', media: 'application/xhtml+xml', title: 'CH03', level: 1),
|
288
|
+
ReVIEW::EPUBMaker::Content.new(file: 'ch03.html#S1', id: 'ch03-html#S1', media: 'html#s1', title: 'CH03.1', level: 2),
|
289
|
+
ReVIEW::EPUBMaker::Content.new(file: 'ch03.html#S1.1', id: 'ch03-html#S1-1', media: '1', title: 'CH03.1.1', level: 3),
|
290
|
+
ReVIEW::EPUBMaker::Content.new(file: 'ch04.html', id: 'ch04-html', media: 'application/xhtml+xml', title: 'CH04', level: 1),
|
291
|
+
ReVIEW::EPUBMaker::Content.new(file: 'sample.png', id: 'sample-png', media: 'image/png'),
|
292
|
+
ReVIEW::EPUBMaker::Content.new(file: 'sample.jpg', id: 'sample-jpg', media: 'image/jpeg'),
|
293
|
+
ReVIEW::EPUBMaker::Content.new(file: 'sample.JPEG', id: 'sample-JPEG', media: 'image/jpeg'),
|
294
|
+
ReVIEW::EPUBMaker::Content.new(file: 'sample.SvG', id: 'sample-SvG', media: 'image/svg+xml'),
|
295
|
+
ReVIEW::EPUBMaker::Content.new(file: 'sample.GIF', id: 'sample-GIF', media: 'image/gif'),
|
296
|
+
ReVIEW::EPUBMaker::Content.new(file: 'sample.css', id: 'sample-css', media: 'text/css')
|
293
297
|
]
|
294
298
|
|
295
299
|
assert_equal expect, @producer.contents
|
@@ -297,7 +301,7 @@ EOT
|
|
297
301
|
|
298
302
|
def test_stage3_opf
|
299
303
|
stage3
|
300
|
-
@producer.opf
|
304
|
+
output = @producer.instance_eval { @epub.opf }
|
301
305
|
expect = <<EOT
|
302
306
|
<?xml version="1.0" encoding="UTF-8"?>
|
303
307
|
<package version="2.0" xmlns="http://www.idpf.org/2007/opf" unique-identifier="BookId">
|
@@ -333,12 +337,12 @@ EOT
|
|
333
337
|
</guide>
|
334
338
|
</package>
|
335
339
|
EOT
|
336
|
-
assert_equal expect,
|
340
|
+
assert_equal expect, output
|
337
341
|
end
|
338
342
|
|
339
343
|
def test_stage3_ncx
|
340
344
|
stage3
|
341
|
-
@producer.ncx(
|
345
|
+
output = @producer.instance_eval { @epub.ncx([]) }
|
342
346
|
expect = <<EOT
|
343
347
|
<?xml version="1.0" encoding="UTF-8"?>
|
344
348
|
<ncx xmlns="http://www.daisy.org/z3986/2005/ncx/" version="2005-1">
|
@@ -442,12 +446,14 @@ EOT
|
|
442
446
|
</navMap>
|
443
447
|
</ncx>
|
444
448
|
EOT
|
445
|
-
assert_equal expect,
|
449
|
+
assert_equal expect, output
|
446
450
|
end
|
447
451
|
|
448
452
|
def test_stage3_mytoc
|
449
453
|
stage3
|
450
|
-
@producer.
|
454
|
+
@producer.config['toclevel'] = 2
|
455
|
+
@producer.modify_config
|
456
|
+
output = @producer.instance_eval { @epub.mytoc }
|
451
457
|
expect = <<EOT
|
452
458
|
<?xml version="1.0" encoding="UTF-8"?>
|
453
459
|
<!DOCTYPE html>
|
@@ -472,13 +478,17 @@ EOT
|
|
472
478
|
</ul></body>
|
473
479
|
</html>
|
474
480
|
EOT
|
475
|
-
assert_equal expect,
|
481
|
+
assert_equal expect, output
|
476
482
|
end
|
477
483
|
|
478
484
|
def test_stage3_flat
|
479
|
-
@producer.
|
485
|
+
@producer.config.deep_merge!(
|
486
|
+
'epubmaker' => { 'flattoc' => true, 'flattocindent' => false },
|
487
|
+
'toclevel' => 2
|
488
|
+
)
|
489
|
+
@producer.modify_config
|
480
490
|
stage3
|
481
|
-
@producer.mytoc
|
491
|
+
output = @producer.instance_eval { @epub.mytoc }
|
482
492
|
expect = <<EOT
|
483
493
|
<?xml version="1.0" encoding="UTF-8"?>
|
484
494
|
<!DOCTYPE html>
|
@@ -502,12 +512,12 @@ EOT
|
|
502
512
|
</body>
|
503
513
|
</html>
|
504
514
|
EOT
|
505
|
-
assert_equal expect,
|
515
|
+
assert_equal expect, output
|
506
516
|
end
|
507
517
|
|
508
518
|
def test_stage3_cover
|
509
519
|
stage3
|
510
|
-
@producer.cover
|
520
|
+
output = @producer.instance_eval { @epub.cover }
|
511
521
|
expect = <<EOT
|
512
522
|
<?xml version="1.0" encoding="UTF-8"?>
|
513
523
|
<!DOCTYPE html>
|
@@ -522,13 +532,14 @@ EOT
|
|
522
532
|
</body>
|
523
533
|
</html>
|
524
534
|
EOT
|
525
|
-
assert_equal expect,
|
535
|
+
assert_equal expect, output
|
526
536
|
end
|
527
537
|
|
528
538
|
def test_stage3_cover_escape
|
529
539
|
stage3
|
530
540
|
@producer.config['title'] = 'Sample<>Book'
|
531
|
-
@producer.
|
541
|
+
@producer.modify_config
|
542
|
+
output = @producer.instance_eval { @epub.cover }
|
532
543
|
expect = <<EOT
|
533
544
|
<?xml version="1.0" encoding="UTF-8"?>
|
534
545
|
<!DOCTYPE html>
|
@@ -543,13 +554,14 @@ EOT
|
|
543
554
|
</body>
|
544
555
|
</html>
|
545
556
|
EOT
|
546
|
-
assert_equal expect,
|
557
|
+
assert_equal expect, output
|
547
558
|
end
|
548
559
|
|
549
560
|
def test_stage3_cover_with_image
|
550
561
|
stage3
|
551
562
|
@producer.config['coverimage'] = 'sample.png'
|
552
|
-
@producer.
|
563
|
+
@producer.modify_config
|
564
|
+
output = @producer.instance_eval { @epub.cover }
|
553
565
|
expect = <<EOT
|
554
566
|
<?xml version="1.0" encoding="UTF-8"?>
|
555
567
|
<!DOCTYPE html>
|
@@ -566,14 +578,17 @@ EOT
|
|
566
578
|
</body>
|
567
579
|
</html>
|
568
580
|
EOT
|
569
|
-
assert_equal expect,
|
581
|
+
assert_equal expect, output
|
570
582
|
end
|
571
583
|
|
572
584
|
def test_stage3_cover_with_image_escape
|
573
585
|
stage3
|
574
|
-
@producer.config
|
575
|
-
|
576
|
-
|
586
|
+
@producer.config.merge!(
|
587
|
+
'title' => 'Sample<>Book',
|
588
|
+
'coverimage' => 'sample.png'
|
589
|
+
)
|
590
|
+
@producer.modify_config
|
591
|
+
output = @producer.instance_eval { @epub.cover }
|
577
592
|
expect = <<EOT
|
578
593
|
<?xml version="1.0" encoding="UTF-8"?>
|
579
594
|
<!DOCTYPE html>
|
@@ -590,14 +605,17 @@ EOT
|
|
590
605
|
</body>
|
591
606
|
</html>
|
592
607
|
EOT
|
593
|
-
assert_equal expect,
|
608
|
+
assert_equal expect, output
|
594
609
|
end
|
595
610
|
|
596
611
|
def test_colophon_default
|
597
|
-
@producer.config
|
598
|
-
|
599
|
-
|
600
|
-
|
612
|
+
@producer.config.merge!(
|
613
|
+
'aut' => ['Mr.Smith'],
|
614
|
+
'pbl' => ['BLUEPRINT'],
|
615
|
+
'isbn' => '9784797372274'
|
616
|
+
)
|
617
|
+
@producer.modify_config
|
618
|
+
output = @producer.instance_eval { @epub.colophon }
|
601
619
|
expect = <<EOT
|
602
620
|
<?xml version="1.0" encoding="UTF-8"?>
|
603
621
|
<!DOCTYPE html>
|
@@ -622,17 +640,20 @@ EOT
|
|
622
640
|
</body>
|
623
641
|
</html>
|
624
642
|
EOT
|
625
|
-
assert_equal expect,
|
643
|
+
assert_equal expect, output
|
626
644
|
end
|
627
645
|
|
628
646
|
def test_colophon_default_escape_and_multiple
|
629
|
-
@producer.config
|
630
|
-
|
631
|
-
|
632
|
-
|
633
|
-
|
634
|
-
|
635
|
-
|
647
|
+
@producer.config.merge!(
|
648
|
+
'title' => '<&Sample Book>',
|
649
|
+
'subtitle' => 'Sample<>Subtitle',
|
650
|
+
'aut' => ['Mr.Smith', 'Mr.&Anderson'],
|
651
|
+
'pbl' => ['BLUEPRINT', 'COPY<>EDIT'],
|
652
|
+
'isbn' => '9784797372274',
|
653
|
+
'rights' => ['COPYRIGHT 2016 <>', '& REVIEW']
|
654
|
+
)
|
655
|
+
@producer.modify_config
|
656
|
+
output = @producer.instance_eval { @epub.colophon }
|
636
657
|
expect = <<EOT
|
637
658
|
<?xml version="1.0" encoding="UTF-8"?>
|
638
659
|
<!DOCTYPE html>
|
@@ -658,19 +679,22 @@ EOT
|
|
658
679
|
</body>
|
659
680
|
</html>
|
660
681
|
EOT
|
661
|
-
assert_equal expect,
|
682
|
+
assert_equal expect, output
|
662
683
|
end
|
663
684
|
|
664
685
|
def test_colophon_history
|
665
|
-
@producer.config
|
666
|
-
|
667
|
-
|
668
|
-
|
669
|
-
|
686
|
+
@producer.config.merge!(
|
687
|
+
'aut' => ['Mr.Smith'],
|
688
|
+
'pbl' => ['BLUEPRINT'],
|
689
|
+
'pht' => ['Mrs.Smith'],
|
690
|
+
'language' => 'ja',
|
691
|
+
'history' =>
|
670
692
|
[['2011-08-03',
|
671
693
|
'2012-02-15'],
|
672
694
|
['2012-10-01'],
|
673
695
|
['2013-03-01']]
|
696
|
+
)
|
697
|
+
@producer.modify_config
|
674
698
|
epub = @producer.instance_eval { @epub }
|
675
699
|
result = epub.colophon_history
|
676
700
|
expect = <<-EOT
|
@@ -685,14 +709,17 @@ EOT
|
|
685
709
|
end
|
686
710
|
|
687
711
|
def test_colophon_history_freeformat
|
688
|
-
@producer.config
|
689
|
-
|
690
|
-
|
691
|
-
|
692
|
-
|
712
|
+
@producer.config.merge!(
|
713
|
+
'aut' => ['Mr.Smith'],
|
714
|
+
'pbl' => ['BLUEPRINT'],
|
715
|
+
'pht' => ['Mrs.Smith'],
|
716
|
+
'language' => 'ja',
|
717
|
+
'history' =>
|
693
718
|
[['2011年8月3日 ver 1.1.0発行'],
|
694
719
|
['2011年10月12日 ver 1.2.0発行'],
|
695
720
|
['2012年1月31日 ver 1.2.1発行']]
|
721
|
+
)
|
722
|
+
@producer.modify_config
|
696
723
|
|
697
724
|
epub = @producer.instance_eval { @epub }
|
698
725
|
result = epub.colophon_history
|
@@ -707,10 +734,13 @@ EOT
|
|
707
734
|
end
|
708
735
|
|
709
736
|
def test_colophon_pht
|
710
|
-
@producer.config
|
711
|
-
|
712
|
-
|
713
|
-
|
737
|
+
@producer.config.merge!(
|
738
|
+
'aut' => ['Mr.Smith'],
|
739
|
+
'pbl' => ['BLUEPRINT'],
|
740
|
+
'pht' => ['Mrs.Smith']
|
741
|
+
)
|
742
|
+
@producer.modify_config
|
743
|
+
output = @producer.instance_eval { @epub.colophon }
|
714
744
|
expect = <<EOT
|
715
745
|
<?xml version="1.0" encoding="UTF-8"?>
|
716
746
|
<!DOCTYPE html>
|
@@ -735,28 +765,37 @@ EOT
|
|
735
765
|
</body>
|
736
766
|
</html>
|
737
767
|
EOT
|
738
|
-
assert_equal expect,
|
768
|
+
assert_equal expect, output
|
739
769
|
end
|
740
770
|
|
741
771
|
def test_isbn13
|
742
772
|
@producer.config['isbn'] = '9784797372274'
|
743
|
-
|
773
|
+
@producer.modify_config
|
774
|
+
isbn = @producer.instance_eval { @epub.isbn_hyphen }
|
775
|
+
assert_equal '978-4-79737-227-4', isbn
|
744
776
|
end
|
745
777
|
|
746
778
|
def test_isbn10
|
747
779
|
@producer.config['isbn'] = '4797372273'
|
748
|
-
|
780
|
+
@producer.modify_config
|
781
|
+
isbn = @producer.instance_eval { @epub.isbn_hyphen }
|
782
|
+
assert_equal '4-79737-227-3', isbn
|
749
783
|
end
|
750
784
|
|
751
785
|
def test_isbn_nil
|
752
786
|
@producer.config['isbn'] = nil
|
753
|
-
|
787
|
+
@producer.modify_config
|
788
|
+
isbn = @producer.instance_eval { @epub.isbn_hyphen }
|
789
|
+
assert_equal nil, isbn
|
754
790
|
end
|
755
791
|
|
756
792
|
def test_title
|
757
|
-
@producer.config
|
758
|
-
|
759
|
-
|
793
|
+
@producer.config.merge!(
|
794
|
+
'aut' => ['Mr.Smith'],
|
795
|
+
'pbl' => ['BLUEPRINT']
|
796
|
+
)
|
797
|
+
@producer.modify_config
|
798
|
+
output = @producer.instance_eval { @epub.titlepage }
|
760
799
|
expect = <<EOT
|
761
800
|
<?xml version="1.0" encoding="UTF-8"?>
|
762
801
|
<!DOCTYPE html>
|
@@ -783,13 +822,16 @@ EOT
|
|
783
822
|
</body>
|
784
823
|
</html>
|
785
824
|
EOT
|
786
|
-
assert_equal expect,
|
825
|
+
assert_equal expect, output
|
787
826
|
end
|
788
827
|
|
789
828
|
def test_title_single_value_param
|
790
|
-
@producer.config
|
791
|
-
|
792
|
-
|
829
|
+
@producer.config.merge!(
|
830
|
+
'aut' => 'Mr.Smith',
|
831
|
+
'pbl' => 'BLUEPRINT'
|
832
|
+
)
|
833
|
+
@producer.modify_config
|
834
|
+
output = @producer.instance_eval { @epub.titlepage }
|
793
835
|
expect = <<EOT
|
794
836
|
<?xml version="1.0" encoding="UTF-8"?>
|
795
837
|
<!DOCTYPE html>
|
@@ -816,6 +858,89 @@ EOT
|
|
816
858
|
</body>
|
817
859
|
</html>
|
818
860
|
EOT
|
819
|
-
assert_equal expect,
|
861
|
+
assert_equal expect, output
|
862
|
+
end
|
863
|
+
|
864
|
+
def test_epub_unsafe_id
|
865
|
+
content = ReVIEW::EPUBMaker::Content.new(file: 'sample.png')
|
866
|
+
assert_equal 'sample-png', content.id
|
867
|
+
content = ReVIEW::EPUBMaker::Content.new(file: 'sample-&()-=+@:,漢字.png')
|
868
|
+
assert_equal 'sample-_25_26_25_28_25_29-_25_3D_25_2B_25_40_25_3A_25_2C_25_E6_25_BC_25_A2_25_E5_25_AD_25_97-png', content.id
|
869
|
+
end
|
870
|
+
|
871
|
+
def epubmaker_instance
|
872
|
+
Dir.mktmpdir do |tmpdir|
|
873
|
+
epubmaker = ReVIEW::EPUBMaker.new
|
874
|
+
epubmaker.instance_eval do
|
875
|
+
@config = ReVIEW::Configure.create(maker: 'epubmaker')
|
876
|
+
@config['titlepage'] = nil
|
877
|
+
@producer = ReVIEW::EPUBMaker::Producer.new(@config)
|
878
|
+
|
879
|
+
@htmltoc = ReVIEW::HTMLToc.new(tmpdir)
|
880
|
+
|
881
|
+
def config
|
882
|
+
@config
|
883
|
+
end
|
884
|
+
|
885
|
+
def error(s)
|
886
|
+
raise ApplicationError, s
|
887
|
+
end
|
888
|
+
end
|
889
|
+
|
890
|
+
File.write(File.join(tmpdir, 'exist.css'), 'body {}')
|
891
|
+
File.write(File.join(tmpdir, 'exist.html'), '<html></html>')
|
892
|
+
|
893
|
+
Dir.chdir(tmpdir) do
|
894
|
+
Dir.mkdir('test')
|
895
|
+
yield(epubmaker, File.join(tmpdir, 'test'))
|
896
|
+
end
|
897
|
+
end
|
898
|
+
end
|
899
|
+
|
900
|
+
def test_copy_static_file
|
901
|
+
epubmaker_instance do |epubmaker, tmpdir|
|
902
|
+
epubmaker.config['stylesheet'] = ['exist.css']
|
903
|
+
assert_nothing_raised { epubmaker.copy_stylesheet(tmpdir) }
|
904
|
+
|
905
|
+
epubmaker.config['stylesheet'] = ['nothing.css']
|
906
|
+
assert_raise(SystemExit) { epubmaker.copy_stylesheet(tmpdir) }
|
907
|
+
assert_equal "ERROR --: stylesheet: nothing.css is not found.\n", @log_io.string
|
908
|
+
end
|
909
|
+
|
910
|
+
epubmaker_instance do |epubmaker, tmpdir|
|
911
|
+
epubmaker.config['titlepage'] = true
|
912
|
+
epubmaker.config['titlefile'] = 'exist.html'
|
913
|
+
assert_nothing_raised { epubmaker.copy_frontmatter(tmpdir) }
|
914
|
+
|
915
|
+
epubmaker.config['titlefile'] = 'nothing.html'
|
916
|
+
@log_io.string = ''
|
917
|
+
assert_raise(SystemExit) { epubmaker.copy_frontmatter(tmpdir) }
|
918
|
+
assert_equal "ERROR --: titlefile: nothing.html is not found.\n", @log_io.string
|
919
|
+
end
|
920
|
+
|
921
|
+
# XXX: only `cover' is allowed to have invalid file name.
|
922
|
+
%w[originaltitlefile creditfile].each do |name|
|
923
|
+
epubmaker_instance do |epubmaker, tmpdir|
|
924
|
+
epubmaker.config[name] = 'exist.html'
|
925
|
+
assert_nothing_raised { epubmaker.copy_frontmatter(tmpdir) }
|
926
|
+
|
927
|
+
epubmaker.config[name] = 'nothing.html'
|
928
|
+
@log_io.string = ''
|
929
|
+
assert_raise(SystemExit) { epubmaker.copy_frontmatter(tmpdir) }
|
930
|
+
assert_equal "ERROR --: #{name}: nothing.html is not found.\n", @log_io.string
|
931
|
+
end
|
932
|
+
end
|
933
|
+
|
934
|
+
%w[profile advfile colophon backcover].each do |name|
|
935
|
+
epubmaker_instance do |epubmaker, tmpdir|
|
936
|
+
epubmaker.config[name] = 'exist.html'
|
937
|
+
assert_nothing_raised { epubmaker.copy_backmatter(tmpdir) }
|
938
|
+
|
939
|
+
epubmaker.config[name] = 'nothing.html'
|
940
|
+
@log_io.string = ''
|
941
|
+
assert_raise(SystemExit) { epubmaker.copy_backmatter(tmpdir) }
|
942
|
+
assert_equal "ERROR --: #{name}: nothing.html is not found.\n", @log_io.string
|
943
|
+
end
|
944
|
+
end
|
820
945
|
end
|
821
946
|
end
|