review 4.0.0 → 5.1.1

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