spec/isodoc/postproc_spec.rb in isodoc-1.1.4 vs spec/isodoc/postproc_spec.rb in isodoc-1.2.0
- old
+ new
@@ -1,1558 +1,1536 @@
# frozen_string_literal: true
-require 'spec_helper'
-require 'fileutils'
+require "spec_helper"
+require "fileutils"
RSpec.describe IsoDoc do
- it 'generates file based on string input' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', filename: 'test').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <bibdata>
- <title language="en">test</title>
- </bibdata>
- <preface><foreword>
- <note>
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
- </note>
- </foreword></preface>
- </iso-standard>
+ it "generates file based on string input" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", filename: "test"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <bibdata>
+ <title language="en">test</title>
+ </bibdata>
+ <preface><foreword>
+ <note>
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
+</note>
+ </foreword></preface>
+ </iso-standard>
INPUT
- expect(File.exist?('test.html')).to be true
- html = File.read('test.html')
+ expect(File.exist?("test.html")).to be true
+ html = File.read("test.html")
expect(html).to match(%r{<title>test</title>})
expect(html).to match(/another empty stylesheet/)
expect(html).to match(%r{cdnjs\.cloudflare\.com/ajax/libs/mathjax/})
expect(html).to match(/delimiters: \[\['\(#\(', '\)#\)'\]\]/)
end
- it 'ignores Liquid markup in the document body' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <bibdata>
- <title language="en">test</title>
- </bibdata>
- <preface><foreword>
- <note>
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">{% elif %}These results are based on a study carried out on three different types of kernel.</p>
- </note>
- </foreword></preface>
- </iso-standard>
+ it "ignores Liquid markup in the document body" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::HtmlConvert.new(wordstylesheet: "spec/assets/word.css").convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <bibdata>
+ <title language="en">test</title>
+ </bibdata>
+ <preface><foreword>
+ <note>
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">{% elif %}These results are based on a study carried out on three different types of kernel.</p>
+</note>
+ </foreword></preface>
+ </iso-standard>
INPUT
- expect(File.exist?('test.html')).to be true
- html = File.read('test.html')
+expect(File.exist?("test.html")).to be true
+ html = File.read("test.html")
end
- it 'ignores Liquid markup in the document body (Word)' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <bibdata>
- <title language="en">test</title>
- </bibdata>
- <preface><foreword>
- <note>
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">{% elif %}These results are based on a study carried out on three different types of kernel.</p>
- </note>
- </foreword></preface>
- </iso-standard>
+ it "ignores Liquid markup in the document body (Word)" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <bibdata>
+ <title language="en">test</title>
+ </bibdata>
+ <preface><foreword>
+ <note>
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">{% elif %}These results are based on a study carried out on three different types of kernel.</p>
+</note>
+ </foreword></preface>
+ </iso-standard>
INPUT
- expect(File.exist?('test.doc')).to be true
- html = File.read('test.doc')
+expect(File.exist?("test.doc")).to be true
+ html = File.read("test.doc")
end
- it 'generates HTML output docs with null configuration' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <note>
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
- </note>
- </foreword></preface>
- </iso-standard>
+ it "generates HTML output docs with null configuration" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <note>
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
+</note>
+ </foreword></preface>
+ </iso-standard>
INPUT
- expect(File.exist?('test.html')).to be true
- html = File.read('test.html')
+ expect(File.exist?("test.html")).to be true
+ html = File.read("test.html")
expect(html).not_to match(%r{<title>test</title>})
expect(html).not_to match(/another empty stylesheet/)
expect(html).to match(%r{cdnjs\.cloudflare\.com/ajax/libs/mathjax/})
expect(html).to match(/delimiters: \[\['\(#\(', '\)#\)'\]\]/)
end
- it 'generates Word output docs with null configuration' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <note>
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
- </note>
- </foreword></preface>
- </iso-standard>
+ it "generates Word output docs with null configuration" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <note>
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
+</note>
+ </foreword></preface>
+ </iso-standard>
INPUT
- expect(File.exist?('test.doc')).to be true
- word = File.read('test.doc')
+ expect(File.exist?("test.doc")).to be true
+ word = File.read("test.doc")
expect(word).to match(/one empty stylesheet/)
expect(word).to match(/div\.table_container/)
end
- it 'generates HTML output docs with null configuration from file' do
- FileUtils.rm_f 'spec/assets/iso.doc'
- FileUtils.rm_f 'spec/assets/iso.html'
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('spec/assets/iso.xml', nil, false)
- expect(File.exist?('spec/assets/iso.html')).to be true
- html = File.read('spec/assets/iso.html')
+ it "generates HTML output docs with null configuration from file" do
+ FileUtils.rm_f "spec/assets/iso.doc"
+ FileUtils.rm_f "spec/assets/iso.html"
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("spec/assets/iso.xml", nil, false)
+ expect(File.exist?("spec/assets/iso.html")).to be true
+ html = File.read("spec/assets/iso.html")
expect(html).to match(/another empty stylesheet/)
expect(html).to match(%r{https://use.fontawesome.com})
expect(html).to match(%r{libs/jquery})
end
- it 'generates Headless HTML output docs with null configuration from file' do
- FileUtils.rm_f 'spec/assets/iso.html'
- IsoDoc::HeadlessHtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('spec/assets/iso.xml', nil, false)
- expect(File.exist?('spec/assets/iso.headless.html')).to be true
- html = File.read('spec/assets/iso.headless.html')
+ it "generates Headless HTML output docs with null configuration from file" do
+ FileUtils.rm_f "spec/assets/iso.html"
+ IsoDoc::HeadlessHtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("spec/assets/iso.xml", nil, false)
+ expect(File.exist?("spec/assets/iso.headless.html")).to be true
+ html = File.read("spec/assets/iso.headless.html")
expect(html).not_to match(/another empty stylesheet/)
expect(html).not_to match(%r{https://use.fontawesome.com})
expect(html).not_to match(%r{libs/jquery})
expect(html).not_to match(%r{<html})
expect(html).not_to match(%r{<head})
expect(html).not_to match(%r{<body})
expect(html).to match(%r{<div})
end
- it 'generates Word output docs with null configuration from file' do
- FileUtils.rm_f 'spec/assets/iso.doc'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('spec/assets/iso.xml', nil, false)
- expect(File.exist?('spec/assets/iso.doc')).to be true
- word = File.read('spec/assets/iso.doc')
+ it "generates Word output docs with null configuration from file" do
+ FileUtils.rm_f "spec/assets/iso.doc"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("spec/assets/iso.xml", nil, false)
+ expect(File.exist?("spec/assets/iso.doc")).to be true
+ word = File.read("spec/assets/iso.doc")
expect(word).to match(/one empty stylesheet/)
end
- it 'generates HTML output docs with complete configuration' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::HtmlConvert.new(bodyfont: 'Zapf', htmlstylesheet: 'spec/assets/html.scss', htmlcoverpage: 'spec/assets/htmlcover.html', htmlintropage: 'spec/assets/htmlintro.html', scripts: 'spec/assets/scripts.html', i18nyaml: 'spec/assets/i18n.yaml', ulstyle: 'l1', olstyle: 'l2').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <note>
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
- </note>
- </foreword></preface>
- </iso-standard>
+ it "generates HTML output docs with complete configuration" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::HtmlConvert.new({bodyfont: "Zapf", htmlstylesheet: "spec/assets/html.scss", htmlcoverpage: "spec/assets/htmlcover.html", htmlintropage: "spec/assets/htmlintro.html", scripts: "spec/assets/scripts.html", i18nyaml: "spec/assets/i18n.yaml", ulstyle: "l1", olstyle: "l2"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <note>
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
+</note>
+ </foreword></preface>
+ </iso-standard>
INPUT
- html = File.read('test.html')
+ html = File.read("test.html")
expect(html).to match(/another empty stylesheet/)
expect(html).to match(/font-family: Zapf/)
expect(html).to match(/an empty html cover page/)
expect(html).to match(/an empty html intro page/)
expect(html).to match(/This is > a script/)
expect(html).not_to match(/CDATA/)
- expect(html).to match(%r{Enkonduko</h1>})
+ expect(html).to match(%r{Antaŭparolo</h1>})
end
- it 'generates HTML output docs with default fonts' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::HtmlConvert.new(htmlstylesheet: 'spec/assets/html.scss', htmlcoverpage: 'spec/assets/htmlcover.html', htmlintropage: 'spec/assets/htmlintro.html', scripts: 'spec/assets/scripts.html', i18nyaml: 'spec/assets/i18n.yaml', ulstyle: 'l1', olstyle: 'l2').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <note>
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
- </note>
- </foreword></preface>
- </iso-standard>
+ it "generates HTML output docs with default fonts" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::HtmlConvert.new({htmlstylesheet: "spec/assets/html.scss", htmlcoverpage: "spec/assets/htmlcover.html", htmlintropage: "spec/assets/htmlintro.html", scripts: "spec/assets/scripts.html", i18nyaml: "spec/assets/i18n.yaml", ulstyle: "l1", olstyle: "l2"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <note>
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
+</note>
+ </foreword></preface>
+ </iso-standard>
INPUT
- html = File.read('test.html')
+ html = File.read("test.html")
expect(html).to match(/another empty stylesheet/)
expect(html).to match(/font-family: Arial/)
expect(html).to match(/an empty html cover page/)
expect(html).to match(/an empty html intro page/)
expect(html).to match(/This is > a script/)
expect(html).not_to match(/CDATA/)
- expect(html).to match(%r{Enkonduko</h1>})
+ expect(html).to match(%r{Antaŭparolo</h1>})
end
- it 'generates Word output docs with complete configuration' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::WordConvert.new(bodyfont: 'Zapf', wordstylesheet: 'spec/assets/html.scss', standardstylesheet: 'spec/assets/std.css', header: 'spec/assets/header.html', wordcoverpage: 'spec/assets/wordcover.html', wordintropage: 'spec/assets/wordintro.html', i18nyaml: 'spec/assets/i18n.yaml', ulstyle: 'l1', olstyle: 'l2').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <note>
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
- </note>
- </foreword></preface>
- </iso-standard>
+ it "generates Word output docs with complete configuration" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::WordConvert.new({bodyfont: "Zapf", wordstylesheet: "spec/assets/html.scss", standardstylesheet: "spec/assets/std.css", header: "spec/assets/header.html", wordcoverpage: "spec/assets/wordcover.html", wordintropage: "spec/assets/wordintro.html", i18nyaml: "spec/assets/i18n.yaml", ulstyle: "l1", olstyle: "l2"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <note>
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
+</note>
+ </foreword></preface>
+ </iso-standard>
INPUT
- word = File.read('test.doc')
+ word = File.read("test.doc")
expect(word).to match(/another empty stylesheet/)
expect(word).to match(/font-family: Zapf/)
expect(word).to match(/a third empty stylesheet/)
- # expect(word).to match(/<title>test<\/title>/)
+ #expect(word).to match(/<title>test<\/title>/)
expect(word).to match(/test_files\/header.html/)
expect(word).to match(/an empty word cover page/)
expect(word).to match(/an empty word intro page/)
- expect(word).to match(%r{Enkonduko</h1>})
+ expect(word).to match(%r{Antaŭparolo</h1>})
end
- it 'generates Word output docs with default fonts' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/html.scss', standardstylesheet: 'spec/assets/std.css', header: 'spec/assets/header.html', wordcoverpage: 'spec/assets/wordcover.html', wordintropage: 'spec/assets/wordintro.html', i18nyaml: 'spec/assets/i18n.yaml', ulstyle: 'l1', olstyle: 'l2').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <note>
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
- </note>
- </foreword></preface>
- </iso-standard>
+ it "generates Word output docs with default fonts" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/html.scss", standardstylesheet: "spec/assets/std.css", header: "spec/assets/header.html", wordcoverpage: "spec/assets/wordcover.html", wordintropage: "spec/assets/wordintro.html", i18nyaml: "spec/assets/i18n.yaml", ulstyle: "l1", olstyle: "l2"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <note>
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
+</note>
+ </foreword></preface>
+ </iso-standard>
INPUT
- word = File.read('test.doc')
+ word = File.read("test.doc")
expect(word).to match(/another empty stylesheet/)
expect(word).to match(/font-family: Arial/)
expect(word).to match(/a third empty stylesheet/)
- # expect(word).to match(/<title>test<\/title>/)
+ #expect(word).to match(/<title>test<\/title>/)
expect(word).to match(/test_files\/header.html/)
expect(word).to match(/an empty word cover page/)
expect(word).to match(/an empty word intro page/)
- expect(word).to match(%r{Enkonduko</h1>})
+ expect(word).to match(%r{Antaŭparolo</h1>})
end
- it 'converts definition lists to tables for Word' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <dl>
- <dt>Term</dt>
- <dd>Definition</dd>
- <dt>Term 2</dt>
- <dd>Definition 2</dd>
- </dl>
- </foreword></preface>
- </iso-standard>
+ it "converts definition lists to tables for Word" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <dl>
+ <dt>Term</dt>
+ <dd>Definition</dd>
+ <dt>Term 2</dt>
+ <dd>Definition 2</dd>
+ </dl>
+ </foreword></preface>
+ </iso-standard>
INPUT
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">')
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">').
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <div class="WordSection2">
- <p class="MsoNormal"><br clear="all" style="mso-special-character:line-break;page-break-before:always"/></p>
- <div>
- <h1 class="ForewordTitle">Foreword</h1>
- <table class="dl">
- <tr>
- <td valign="top" align="left">
- <p align="left" style="margin-left:0pt;text-align:left;" class="MsoNormal">Term</p>
- </td>
- <td valign="top">Definition</td>
- </tr>
- <tr>
- <td valign="top" align="left">
- <p align="left" style="margin-left:0pt;text-align:left;" class="MsoNormal">Term 2</p>
- </td>
- <td valign="top">Definition 2</td>
- </tr>
- </table>
+ <div class="WordSection2">
+ <p class="MsoNormal"><br clear="all" style="mso-special-character:line-break;page-break-before:always"/></p>
+ <div>
+ <h1 class="ForewordTitle">Foreword</h1>
+ <table class="dl">
+ <tr>
+ <td valign="top" align="left">
+ <p align="left" style="margin-left:0pt;text-align:left;" class="MsoNormal">Term</p>
+ </td>
+ <td valign="top">Definition</td>
+ </tr>
+ <tr>
+ <td valign="top" align="left">
+ <p align="left" style="margin-left:0pt;text-align:left;" class="MsoNormal">Term 2</p>
+ </td>
+ <td valign="top">Definition 2</td>
+ </tr>
+ </table>
+ </div>
+ <p class="MsoNormal"> </p>
</div>
- <p class="MsoNormal"> </p>
- </div>
OUTPUT
end
- it 'populates Word template with terms reference labels' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <sections>
- <terms id="_terms_and_definitions" obligation="normative"><title>Terms and Definitions</title>
-
- <term id="paddy1"><preferred>paddy</preferred>
- <definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
- <termsource status="modified">
- <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011"><locality type="clause"><referenceFrom>3.1</referenceFrom></locality></origin>
- <modification>
- <p id="_e73a417d-ad39-417d-a4c8-20e4e2529489">The term "cargo rice" is shown as deprecated, and Note 1 to entry is not included here</p>
- </modification>
- </termsource></term>
-
- </terms>
- </sections>
- </iso-standard>
-
+ it "populates Word template with terms reference labels" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <sections>
+ <terms id="_terms_and_definitions" obligation="normative"><title>1.<tab/>Terms and Definitions</title>
+<term id="paddy1"><name>1.1.</name><preferred>paddy</preferred>
+<definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
+<termsource status="modified">
+ <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011">ISO 7301:2011, Clause 3.1</origin>
+ <modification>
+ <p id="_e73a417d-ad39-417d-a4c8-20e4e2529489">The term "cargo rice" is shown as deprecated, and Note 1 to entry is not included here</p>
+ </modification>
+</termsource></term>
+</terms>
+</sections>
+</iso-standard>
INPUT
- word = File.read('test.doc').sub(/^.*<div class="WordSection3">/m, '<div class="WordSection3">')
- .sub(%r{<div style="mso-element:footnote-list"/>.*$}m, '')
+ word = File.read("test.doc").sub(/^.*<div class="WordSection3">/m, '<div class="WordSection3">').
+ sub(%r{<div style="mso-element:footnote-list"/>.*$}m, "")
expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <div class="WordSection3">
- <p class="zzSTDTitle1"></p>
- <div><a name="_terms_and_definitions" id="_terms_and_definitions"></a><h1>1.<span style="mso-tab-count:1">  </span>Terms and Definitions</h1>
- <p class="TermNum"><a name="paddy1" id="paddy1"></a>1.1.</p><p class="Terms" style="text-align:left;">paddy</p>
- <p class="MsoNormal"><a name="_eb29b35e-123e-4d1c-b50b-2714d41e747f" id="_eb29b35e-123e-4d1c-b50b-2714d41e747f"></a>rice retaining its husk after threshing</p>
- <p class="MsoNormal">[SOURCE: <a href="#ISO7301">ISO 7301:2011, Clause 3.1</a>, modified — The term "cargo rice" is shown as deprecated, and Note 1 to entry is not included here]</p></div>
- </div>
+ <div class="WordSection3">
+ <p class="zzSTDTitle1"></p>
+ <div><a name="_terms_and_definitions" id="_terms_and_definitions"></a><h1>1.<span style="mso-tab-count:1">  </span>Terms and Definitions</h1>
+ <p class="TermNum"><a name="paddy1" id="paddy1"></a>1.1.</p><p class="Terms" style="text-align:left;">paddy</p>
+ <p class="MsoNormal"><a name="_eb29b35e-123e-4d1c-b50b-2714d41e747f" id="_eb29b35e-123e-4d1c-b50b-2714d41e747f"></a>rice retaining its husk after threshing</p>
+ <p class="MsoNormal">[SOURCE: <a href="#ISO7301">ISO 7301:2011, Clause 3.1</a>, modified — The term "cargo rice" is shown as deprecated, and Note 1 to entry is not included here]</p></div>
+ </div>
OUTPUT
end
- it 'populates Word header' do
- FileUtils.rm_f 'test.doc'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', header: 'spec/assets/header.html').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <bibdata type="article">
- <docidentifier>
- <project-number part="1">1000</project-number>
- </docidentifier>
- </bibdata>
- </iso-standard>
-
+ it "populates Word header" do
+ FileUtils.rm_f "test.doc"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", header: "spec/assets/header.html"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <bibdata type="article">
+ <docidentifier>
+ <project-number part="1">1000</project-number>
+ </docidentifier>
+ </bibdata>
+</iso-standard>
INPUT
- word = File.read('test.doc').sub(%r{^.*Content-Location: file:///C:/Doc/test_files/header.html}m, 'Content-Location: file:///C:/Doc/test_files/header.html')
- .sub(/------=_NextPart.*$/m, '')
+ word = File.read("test.doc").sub(%r{^.*Content-Location: file:///C:/Doc/test_files/header.html}m, "Content-Location: file:///C:/Doc/test_files/header.html").
+ sub(/------=_NextPart.*$/m, "")
expect(word).to be_equivalent_to <<~"OUTPUT"
-
- Content-Location: file:///C:/Doc/test_files/header.html
- Content-Transfer-Encoding: base64
- Content-Type: text/html charset="utf-8"
-
- Ci8qIGFuIGVtcHR5IGhlYWRlciAqLwoKU1RBUlQgRE9DIElEOiAKICAgICAgICAgICAxMDAwCiAg
- ICAgICAgIDogRU5EIERPQyBJRAoKRklMRU5BTUU6IHRlc3QKCg==
-
+Content-Location: file:///C:/Doc/test_files/header.html
+Content-Transfer-Encoding: base64
+Content-Type: text/html charset="utf-8"
+Ci8qIGFuIGVtcHR5IGhlYWRlciAqLwoKU1RBUlQgRE9DIElEOiAKICAgICAgICAgICAxMDAwCiAg
+ICAgICAgIDogRU5EIERPQyBJRAoKRklMRU5BTUU6IHRlc3QKCg==
OUTPUT
end
- it 'populates Word ToC' do
- FileUtils.rm_f 'test.doc'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', wordintropage: 'spec/assets/wordintro.html').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <sections>
- <clause id="A" inline-header="false" obligation="normative"><title>Clause 4</title><clause id="N" inline-header="false" obligation="normative">
-
- <title>Introduction<bookmark id="Q"/> to this<fn reference="1">
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
- </fn></title>
- </clause>
- <clause id="O" inline-header="false" obligation="normative">
- <title>Clause 4.2</title>
- <p>A<fn reference="1">
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
- </fn></p>
- <clause id="P" inline-header="false" obligation="normative">
- <title>Clause 4.2.1</title>
- </clause>
- </clause></clause>
- </sections>
- </iso-standard>
-
+ it "populates Word ToC" do
+ FileUtils.rm_f "test.doc"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", wordintropage: "spec/assets/wordintro.html"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <sections>
+ <clause id="A" inline-header="false" obligation="normative"><title>Clause 4</title><clause id="N" inline-header="false" obligation="normative">
+ <title>Introduction<bookmark id="Q"/> to this<fn reference="1">
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
+</fn></title>
+ </clause>
+ <clause id="O" inline-header="false" obligation="normative">
+ <title>Clause 4.2</title>
+ <p>A<fn reference="1">
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
+</fn></p>
+<clause id="P" inline-header="false" obligation="normative">
+<title>Clause 4.2.1</title>
+</clause>
+ </clause></clause>
+ </sections>
+ </iso-standard>
INPUT
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">')
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
- expect(xmlpp(word.gsub(/_Toc\d\d+/, '_Toc'))).to be_equivalent_to xmlpp(<<~'OUTPUT')
- <div class="WordSection2">
- /* an empty word intro page */
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">').
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
+ expect(xmlpp(word.gsub(/_Toc\d\d+/, "_Toc"))).to be_equivalent_to xmlpp(<<~'OUTPUT')
+ <div class="WordSection2">
+ /* an empty word intro page */
+
<p class="MsoToc1"><span lang="EN-GB" xml:lang="EN-GB"><span style="mso-element:field-begin"></span><span style="mso-spacerun:yes"> </span>TOC
- \o "1-2" \h \z \u <span style="mso-element:field-separator"></span></span>
- <span class="MsoHyperlink"><span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
- <a href="#_Toc">1. Clause 4<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-tab-count:1 dotted">. </span>
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-element:field-begin"></span></span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span></span></p>
+ \o "1-2" \h \z \u <span style="mso-element:field-separator"></span></span>
+ <span class="MsoHyperlink"><span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
+ <a href="#_Toc">Clause 4<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+ <span style="mso-tab-count:1 dotted">. </span>
+ </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+ <span style="mso-element:field-begin"></span></span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span></span></p>
<p class="MsoToc2">
- <span class="MsoHyperlink">
- <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
- <a href="#_Toc">1.1. Introduction to this<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-tab-count:1 dotted">. </span>
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-element:field-begin"></span></span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
- </span>
- </p>
+ <span class="MsoHyperlink">
+ <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
+ <a href="#_Toc">Introduction to this<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+ <span style="mso-tab-count:1 dotted">. </span>
+ </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+ <span style="mso-element:field-begin"></span></span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
+ </span>
+ </p>
<p class="MsoToc2">
- <span class="MsoHyperlink">
- <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
- <a href="#_Toc">1.2. Clause 4.2<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-tab-count:1 dotted">. </span>
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-element:field-begin"></span></span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
- </span>
- </p>
+ <span class="MsoHyperlink">
+ <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
+ <a href="#_Toc">Clause 4.2<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+ <span style="mso-tab-count:1 dotted">. </span>
+ </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+ <span style="mso-element:field-begin"></span></span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
+ </span>
+ </p>
<p class="MsoToc1">
- <span lang="EN-GB" xml:lang="EN-GB">
- <span style="mso-element:field-end"></span>
- </span>
- <span lang="EN-GB" xml:lang="EN-GB">
- <p class="MsoNormal"> </p>
- </span>
- </p>
- <p class="MsoNormal"> </p>
- </div>
+ <span lang="EN-GB" xml:lang="EN-GB">
+ <span style="mso-element:field-end"></span>
+ </span>
+ <span lang="EN-GB" xml:lang="EN-GB">
+ <p class="MsoNormal"> </p>
+ </span>
+ </p>
+ <p class="MsoNormal"> </p>
+ </div>
OUTPUT
end
- it 'populates Word ToC with custom levels' do
- FileUtils.rm_f 'test.doc'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', wordintropage: 'spec/assets/wordintro.html', doctoclevels: 3).convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <sections>
- <clause id="A" inline-header="false" obligation="normative"><title>Clause 4</title><clause id="N" inline-header="false" obligation="normative">
-
- <title>Introduction<bookmark id="Q"/> to this<fn reference="1">
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
- </fn></title>
- </clause>
- <clause id="O" inline-header="false" obligation="normative">
- <title>Clause 4.2</title>
- <p>A<fn reference="1">
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
- </fn></p>
- <clause id="P" inline-header="false" obligation="normative">
- <title>Clause 4.2.1</title>
- </clause>
- </clause></clause>
- </sections>
- </iso-standard>
-
+ it "populates Word ToC with custom levels" do
+ FileUtils.rm_f "test.doc"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", wordintropage: "spec/assets/wordintro.html", doctoclevels: 3}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <sections>
+ <clause id="A" inline-header="false" obligation="normative"><title>Clause 4</title><clause id="N" inline-header="false" obligation="normative">
+ <title>Introduction<bookmark id="Q"/> to this<fn reference="1">
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
+</fn></title>
+ </clause>
+ <clause id="O" inline-header="false" obligation="normative">
+ <title>Clause 4.2</title>
+ <p>A<fn reference="1">
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
+</fn></p>
+<clause id="P" inline-header="false" obligation="normative">
+<title>Clause 4.2.1</title>
+</clause>
+ </clause></clause>
+ </sections>
+ </iso-standard>
INPUT
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">')
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
- expect(xmlpp(word.gsub(/_Toc\d\d+/, '_Toc'))).to be_equivalent_to xmlpp(<<~'OUTPUT')
- <div class="WordSection2">
- /* an empty word intro page */
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">').
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
+ expect(xmlpp(word.gsub(/_Toc\d\d+/, "_Toc"))).to be_equivalent_to xmlpp(<<~'OUTPUT')
+ <div class="WordSection2">
+ /* an empty word intro page */
- <p class="MsoToc1"><span lang="EN-GB" xml:lang="EN-GB"><span style="mso-element:field-begin"></span><span style="mso-spacerun:yes"> </span>TOC
- \o "1-3" \h \z \u <span style="mso-element:field-separator"></span></span>
- <span class="MsoHyperlink"><span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
- <a href="#_Toc">1. Clause 4<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-tab-count:1 dotted">. </span>
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-element:field-begin"></span></span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span></span></p>
-
- <p class="MsoToc2">
- <span class="MsoHyperlink">
- <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
- <a href="#_Toc">1.1. Introduction to this<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-tab-count:1 dotted">. </span>
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-element:field-begin"></span></span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
- </span>
- </p>
-
- <p class="MsoToc2">
- <span class="MsoHyperlink">
- <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
- <a href="#_Toc">1.2. Clause 4.2<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-tab-count:1 dotted">. </span>
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-element:field-begin"></span></span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
- </span>
- </p>
-
- <p class="MsoToc3">
- <span class="MsoHyperlink">
- <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
- <a href="#_Toc">1.2.1. Clause 4.2.1<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-tab-count:1 dotted">. </span>
- </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
- <span style="mso-element:field-begin"></span></span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
- <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
- </span>
- </p>
-
- <p class="MsoToc1">
- <span lang="EN-GB" xml:lang="EN-GB">
- <span style="mso-element:field-end"></span>
- </span>
- <span lang="EN-GB" xml:lang="EN-GB">
- <p class="MsoNormal"> </p>
- </span>
- </p>
-
-
- <p class="MsoNormal"> </p>
- </div>
+ <p class="MsoToc1"><span lang="EN-GB" xml:lang="EN-GB"><span style="mso-element:field-begin"></span><span style="mso-spacerun:yes"> </span>TOC
+ \o "1-3" \h \z \u <span style="mso-element:field-separator"></span></span>
+ <span class="MsoHyperlink"><span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
+ <a href="#_Toc">Clause 4<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+ <span style="mso-tab-count:1 dotted">. </span>
+ </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+ <span style="mso-element:field-begin"></span></span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span></span></p>
+ <p class="MsoToc2">
+ <span class="MsoHyperlink">
+ <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
+ <a href="#_Toc">Introduction to this<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+ <span style="mso-tab-count:1 dotted">. </span>
+ </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+ <span style="mso-element:field-begin"></span></span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
+ </span>
+ </p>
+ <p class="MsoToc2">
+ <span class="MsoHyperlink">
+ <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
+ <a href="#_Toc">Clause 4.2<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+ <span style="mso-tab-count:1 dotted">. </span>
+ </span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+ <span style="mso-element:field-begin"></span></span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
+ </span>
+ </p>
+ <p class="MsoToc3">
+ <span class="MsoHyperlink">
+ <span lang="EN-GB" style="mso-no-proof:yes" xml:lang="EN-GB">
+<a href="#_Toc">Clause 4.2.1<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+<span style="mso-tab-count:1 dotted">. </span>
+</span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">
+<span style="mso-element:field-begin"></span></span>
+<span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"> PAGEREF _Toc \h </span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-separator"></span></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB">1</span>
+ <span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"></span><span lang="EN-GB" class="MsoTocTextSpan" xml:lang="EN-GB"><span style="mso-element:field-end"></span></span></a></span>
+ </span>
+</p>
+ <p class="MsoToc1">
+ <span lang="EN-GB" xml:lang="EN-GB">
+ <span style="mso-element:field-end"></span>
+ </span>
+ <span lang="EN-GB" xml:lang="EN-GB">
+ <p class="MsoNormal"> </p>
+ </span>
+ </p>
+ <p class="MsoNormal"> </p>
+ </div>
OUTPUT
- end
+ end
- it 'generates HTML output with custom ToC levels function' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::HtmlConvert.new(htmltoclevels: 3).convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <note>
- <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
- </note>
- </foreword></preface>
- </iso-standard>
+ it "generates HTML output with custom ToC levels function" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::HtmlConvert.new({htmltoclevels: 3}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <note>
+ <p id="_f06fd0d1-a203-4f3d-a515-0bdba0f8d83f">These results are based on a study carried out on three different types of kernel.</p>
+</note>
+ </foreword></preface>
+ </iso-standard>
INPUT
- html = File.read('test.html')
+ html = File.read("test.html")
toclevel = <<~"TOCLEVEL"
- function toclevel() { return "h1:not(:empty):not(.TermNum):not(.noTOC),h2:not(:empty):not(.TermNum):not(.noTOC),h3:not(:empty):not(.TermNum):not(.noTOC)";}
+function toclevel() { return "h1:not(:empty):not(.TermNum):not(.noTOC),h2:not(:empty):not(.TermNum):not(.noTOC),h3:not(:empty):not(.TermNum):not(.noTOC)";}
TOCLEVEL
expect(html).to include toclevel
end
- it 'reorders footnote numbers in HTML' do
- FileUtils.rm_f 'test.html'
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', wordintropage: 'spec/assets/wordintro.html').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <sections>
- <clause id="A" inline-header="false" obligation="normative"><title>Clause 4</title><fn reference="3">
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">This is a footnote.</p>
- </fn><clause id="N" inline-header="false" obligation="normative">
-
- <title>Introduction to this<fn reference="2">
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
- </fn></title>
- </clause>
- <clause id="O" inline-header="false" obligation="normative">
- <title>Clause 4.2</title>
- <p>A<fn reference="1">
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
- </fn></p>
- </clause></clause>
- </sections>
- </iso-standard>
+ it "reorders footnote numbers in HTML" do
+ FileUtils.rm_f "test.html"
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", wordintropage: "spec/assets/wordintro.html"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <sections>
+ <clause id="A" inline-header="false" obligation="normative"><title>Clause 4</title><fn reference="3">
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">This is a footnote.</p>
+</fn><clause id="N" inline-header="false" obligation="normative">
+ <title>Introduction to this<fn reference="2">
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
+</fn></title>
+ </clause>
+ <clause id="O" inline-header="false" obligation="normative">
+ <title>Clause 4.2</title>
+ <p>A<fn reference="1">
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6">Formerly denoted as 15 % (m/m).</p>
+</fn></p>
+ </clause></clause>
+ </sections>
+ </iso-standard>
INPUT
- html = File.read('test.html').sub(/^.*<main class="main-section">/m, '<main xmlns:epub="epub" class="main-section">')
- .sub(%r{</main>.*$}m, '</main>')
+ html = File.read("test.html").sub(/^.*<main class="main-section">/m, '<main xmlns:epub="epub" class="main-section">').
+ sub(%r{</main>.*$}m, "</main>")
expect(xmlpp(html)).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <main xmlns:epub="epub" class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
- <p class="zzSTDTitle1"></p>
- <div id="A">
- <h1>1.  Clause 4</h1>
- <a class='FootnoteRef' href='#fn:3' id='fnref:1'>
- <sup>1</sup>
- </a>
- <div id="N">
- <h2>1.1.  Introduction to this<a class='FootnoteRef' href='#fn:2' id='fnref:2'><sup>2</sup></a></h2>
+ <main xmlns:epub="epub" class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
+ <p class="zzSTDTitle1"></p>
+ <div id="A">
+ <h1>Clause 4</h1>
+ <a class='FootnoteRef' href='#fn:3' id='fnref:1'>
+ <sup>1</sup>
+ </a>
+ <div id="N">
+ <h2>Introduction to this<a class='FootnoteRef' href='#fn:2' id='fnref:2'><sup>2</sup></a></h2>
+ </div>
+ <div id="O">
+ <h2>Clause 4.2</h2>
+ <p>A<a class='FootnoteRef' href='#fn:2'><sup>2</sup></a></p>
+ </div>
</div>
- <div id="O">
- <h2>1.2.  Clause 4.2</h2>
- <p>A<a class='FootnoteRef' href='#fn:2'><sup>2</sup></a></p>
- </div>
- </div>
- <aside id="fn:3" class="footnote">
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6"><a class='FootnoteRef' href='#fn:3'>
- <sup>1</sup>
- </a>This is a footnote.</p>
- <a href="#fnref:1">↩</a></aside>
- <aside id="fn:2" class="footnote">
- <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6"><a class='FootnoteRef' href='#fn:2'><sup>2</sup></a>Formerly denoted as 15 % (m/m).</p>
- <a href="#fnref:2">↩</a></aside>
+ <aside id="fn:3" class="footnote">
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6"><a class='FootnoteRef' href='#fn:3'>
+ <sup>1</sup>
+ </a>This is a footnote.</p>
+ <a href="#fnref:1">↩</a></aside>
+ <aside id="fn:2" class="footnote">
+ <p id="_ff27c067-2785-4551-96cf-0a73530ff1e6"><a class='FootnoteRef' href='#fn:2'><sup>2</sup></a>Formerly denoted as 15 % (m/m).</p>
+ <a href="#fnref:2">↩</a></aside>
</main>
OUTPUT
end
- it 'moves images in HTML' do
- FileUtils.rm_f 'test.html'
- FileUtils.rm_rf 'test_htmlimages'
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <figure id="_">
- <name>Split-it-right sample divider</name>
- <image src="#{File.expand_path(File.join(File.dirname(__FILE__), '..', 'assets/rice_image1.png'))}" id="_" mimetype="image/png"/>
- <image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
- <image src="spec/assets/rice_image1.png" id="_" width="20000" height="300000" mimetype="image/png"/>
- <image src="spec/assets/rice_image1.png" id="_" width="99" height="auto" mimetype="image/png"/>
- <image src="" id="_8357ede4-6d44-4672-bac4-9a85e82ab7f3" mimetype="image/png"/>
- </figure>
- </foreword></preface>
- </iso-standard>
+ it "moves images in HTML" do
+ FileUtils.rm_f "test.html"
+ FileUtils.rm_rf "test_htmlimages"
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <figure id="_">
+ <name>Split-it-right sample divider</name>
+ <image src="#{File.expand_path(File.join(File.dirname(__FILE__), "..", "assets/rice_image1.png"))}" id="_" mimetype="image/png"/>
+ <image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
+ <image src="spec/assets/rice_image1.png" id="_" width="20000" height="300000" mimetype="image/png"/>
+ <image src="spec/assets/rice_image1.png" id="_" width="99" height="auto" mimetype="image/png"/>
+ <image src="" id="_8357ede4-6d44-4672-bac4-9a85e82ab7f3" mimetype="image/png"/>
+ </figure>
+ </foreword></preface>
+ </iso-standard>
INPUT
- html = File.read('test.html').sub(/^.*<main class="main-section">/m, '<main class="main-section">')
- .sub(%r{</main>.*$}m, '</main>')
+ html = File.read("test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
+ sub(%r{</main>.*$}m, "</main>")
expect(`ls test_htmlimages`).to match(/\.png$/)
- expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, '/_.png'))).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
- <br />
- <div>
- <h1 class="ForewordTitle">Foreword</h1>
- <div id="_" class="figure">
- <img src="test_htmlimages/_.png" height="776" width="922" />
- <img src="test_htmlimages/_.png" height="776" width="922" />
- <img src="test_htmlimages/_.png" height="800" width="53" />
- <img src="test_htmlimages/_.png" height="83" width="99" />
- <img src="" height="800" width="800" />
- <p class="FigureTitle" style="text-align:center;">Figure 1 — Split-it-right sample divider</p></div>
- </div>
- <p class="zzSTDTitle1"></p>
- </main>
+ expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, "/_.png"))).to be_equivalent_to xmlpp(<<~"OUTPUT")
+ <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
+ <br />
+ <div>
+ <h1 class="ForewordTitle">Foreword</h1>
+ <div id="_" class="figure">
+ <img src="test_htmlimages/_.png" height="776" width="922" />
+ <img src="test_htmlimages/_.png" height="776" width="922" />
+<img src="test_htmlimages/_.png" height="800" width="53" />
+<img src="test_htmlimages/_.png" height="83" width="99" />
+<img src="" height="800" width="800" />
+ <p class="FigureTitle" style="text-align:center;">Split-it-right sample divider</p></div>
+ </div>
+ <p class="zzSTDTitle1"></p>
+ </main>
OUTPUT
+
end
- it 'moves images in HTML with no file suffix' do
- FileUtils.rm_f 'test.html'
- FileUtils.rm_rf 'test_htmlimages'
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <figure id="_">
- <name>Split-it-right sample divider</name>
- <image src="spec/assets/rice_image1" id="_" mimetype="image/png"/>
- <image src="spec/assets/rice_image1" id="_" mimetype="image/*"/>
- <image src="" id="_8357ede4-6d44-4672-bac4-9a85e82ab7f3" mimetype="image/png"/>
- </figure>
- </foreword></preface>
- </iso-standard>
+
+ it "moves images in HTML with no file suffix" do
+ FileUtils.rm_f "test.html"
+ FileUtils.rm_rf "test_htmlimages"
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <figure id="_">
+ <name>Split-it-right sample divider</name>
+ <image src="spec/assets/rice_image1" id="_" mimetype="image/png"/>
+ <image src="spec/assets/rice_image1" id="_" mimetype="image/*"/>
+ <image src="" id="_8357ede4-6d44-4672-bac4-9a85e82ab7f3" mimetype="image/png"/>
+ </figure>
+ </foreword></preface>
+ </iso-standard>
INPUT
- html = File.read('test.html').sub(/^.*<main class="main-section">/m, '<main class="main-section">')
- .sub(%r{</main>.*$}m, '</main>')
+ html = File.read("test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
+ sub(%r{</main>.*$}m, "</main>")
expect(`ls test_htmlimages`).to match(/\.png$/)
- expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, '/_.png'))).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <main class='main-section'>
- <button onclick='topFunction()' id='myBtn' title='Go to top'>Top</button>
- <br/>
- <div>
- <h1 class='ForewordTitle'>Foreword</h1>
- <div id='_' class='figure'>
- <img src='test_htmlimages/_.png' height='776' width='922'/>
- <img src='test_htmlimages/_.png' height='776' width='922'/>
- <img src='' height='800' width='800'/>
- <p class='FigureTitle' style='text-align:center;'>Figure 1 — Split-it-right sample divider</p>
- </div>
+ expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, "/_.png"))).to be_equivalent_to xmlpp(<<~"OUTPUT")
+ <main class='main-section'>
+ <button onclick='topFunction()' id='myBtn' title='Go to top'>Top</button>
+ <br/>
+ <div>
+ <h1 class='ForewordTitle'>Foreword</h1>
+ <div id='_' class='figure'>
+ <img src='test_htmlimages/_.png' height='776' width='922'/>
+ <img src='test_htmlimages/_.png' height='776' width='922'/>
+ <img src='' height='800' width='800'/>
+ <p class='FigureTitle' style='text-align:center;'>Split-it-right sample divider</p>
</div>
- <p class='zzSTDTitle1'/>
- </main>
+ </div>
+ <p class='zzSTDTitle1'/>
+ </main>
OUTPUT
end
- it 'moves images in HTML, using relative file location' do
- FileUtils.rm_f 'spec/test.html'
- FileUtils.rm_rf 'spec/test_htmlimages'
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('spec/test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <figure id="_">
- <name>Split-it-right sample divider</name>
- <image src="#{File.expand_path(File.join(File.dirname(__FILE__), '..', 'assets/rice_image1.png'))}" id="_" mimetype="image/png"/>
- <image src="assets/rice_image1.png" id="_" mimetype="image/png"/>
- <image src="assets/rice_image1.png" id="_" width="20000" height="300000" mimetype="image/png"/>
- <image src="assets/rice_image1.png" id="_" width="99" height="auto" mimetype="image/png"/>
- </figure>
- </foreword></preface>
- </iso-standard>
+ it "moves images in HTML, using relative file location" do
+ FileUtils.rm_f "spec/test.html"
+ FileUtils.rm_rf "spec/test_htmlimages"
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("spec/test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <figure id="_">
+ <name>Split-it-right sample divider</name>
+ <image src="#{File.expand_path(File.join(File.dirname(__FILE__), "..", "assets/rice_image1.png"))}" id="_" mimetype="image/png"/>
+ <image src="assets/rice_image1.png" id="_" mimetype="image/png"/>
+ <image src="assets/rice_image1.png" id="_" width="20000" height="300000" mimetype="image/png"/>
+ <image src="assets/rice_image1.png" id="_" width="99" height="auto" mimetype="image/png"/>
+ </figure>
+ </foreword></preface>
+ </iso-standard>
INPUT
- html = File.read('spec/test.html').sub(/^.*<main class="main-section">/m, '<main class="main-section">')
- .sub(%r{</main>.*$}m, '</main>')
+ html = File.read("spec/test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
+ sub(%r{</main>.*$}m, "</main>")
expect(`ls test_htmlimages`).to match(/\.png$/)
- expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, '/_.png'))).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
- <br />
- <div>
- <h1 class="ForewordTitle">Foreword</h1>
- <div id="_" class="figure">
- <img src="test_htmlimages/_.png" height="776" width="922" />
- <img src="test_htmlimages/_.png" height="776" width="922" />
- <img src="test_htmlimages/_.png" height="800" width="53" />
- <img src="test_htmlimages/_.png" height="83" width="99" />
- <p class="FigureTitle" style="text-align:center;">Figure 1 — Split-it-right sample divider</p></div>
- </div>
- <p class="zzSTDTitle1"></p>
- </main>
+ expect(xmlpp(html.gsub(/\/[0-9a-f-]+\.png/, "/_.png"))).to be_equivalent_to xmlpp(<<~"OUTPUT")
+ <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
+ <br />
+ <div>
+ <h1 class="ForewordTitle">Foreword</h1>
+ <div id="_" class="figure">
+ <img src="test_htmlimages/_.png" height="776" width="922" />
+ <img src="test_htmlimages/_.png" height="776" width="922" />
+<img src="test_htmlimages/_.png" height="800" width="53" />
+<img src="test_htmlimages/_.png" height="83" width="99" />
+ <p class="FigureTitle" style="text-align:center;">Split-it-right sample divider</p></div>
+ </div>
+ <p class="zzSTDTitle1"></p>
+ </main>
OUTPUT
end
- it 'encodes images in HTML as data URIs' do
- FileUtils.rm_f 'test.html'
- FileUtils.rm_rf 'test_htmlimages'
- IsoDoc::HtmlConvert.new(htmlstylesheet: 'spec/assets/html.scss', datauriimage: true).convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <figure id="_">
- <name>Split-it-right sample divider</name>
- <image src="#{File.expand_path(File.join(File.dirname(__FILE__), '..', 'assets/rice_image1.png'))}" id="_" mimetype="image/png"/>
- <image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
- </figure>
- </foreword></preface>
- </iso-standard>
+
+ it "encodes images in HTML as data URIs" do
+ FileUtils.rm_f "test.html"
+ FileUtils.rm_rf "test_htmlimages"
+ IsoDoc::HtmlConvert.new({htmlstylesheet: "spec/assets/html.scss", datauriimage: true}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <figure id="_">
+ <name>Split-it-right sample divider</name>
+ <image src="#{File.expand_path(File.join(File.dirname(__FILE__), "..", "assets/rice_image1.png"))}" id="_" mimetype="image/png"/>
+ <image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
+ </figure>
+ </foreword></preface>
+ </iso-standard>
INPUT
- html = File.read('test.html').sub(/^.*<main class="main-section">/m, '<main class="main-section">')
- .sub(%r{</main>.*$}m, '</main>')
+ html = File.read("test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
+ sub(%r{</main>.*$}m, "</main>")
expect(xmlpp(html.gsub(%r{src="data:image/png;base64,[^"]+"}, %{src="data:image/png;base64,_"}))).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
- <br />
- <div>
- <h1 class="ForewordTitle">Foreword</h1>
- <div id="_" class="figure">
- <img src="data:image/png;base64,_" height="776" width="922" />
- <img src="data:image/png;base64,_" height="776" width="922" />
- <p class="FigureTitle" style="text-align:center;">Figure 1 — Split-it-right sample divider</p></div>
- </div>
- <p class="zzSTDTitle1"></p>
- </main>
+ <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
+ <br />
+ <div>
+ <h1 class="ForewordTitle">Foreword</h1>
+ <div id="_" class="figure">
+ <img src="data:image/png;base64,_" height="776" width="922" />
+ <img src="data:image/png;base64,_" height="776" width="922" />
+ <p class="FigureTitle" style="text-align:center;">Split-it-right sample divider</p></div>
+ </div>
+ <p class="zzSTDTitle1"></p>
+ </main>
OUTPUT
+
end
- it 'encodes images in HTML as data URIs, using relative file location' do
- FileUtils.rm_f 'spec/test.html'
- FileUtils.rm_rf 'spec/test_htmlimages'
- IsoDoc::HtmlConvert.new(htmlstylesheet: 'spec/assets/html.scss', datauriimage: true).convert('spec/test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <figure id="_">
- <name>Split-it-right sample divider</name>
- <image src="#{File.expand_path(File.join(File.dirname(__FILE__), '..', 'assets/rice_image1.png'))}" id="_" mimetype="image/png"/>
- <image src="assets/rice_image1.png" id="_" mimetype="image/png"/>
- </figure>
- </foreword></preface>
- </iso-standard>
+ it "encodes images in HTML as data URIs, using relative file location" do
+ FileUtils.rm_f "spec/test.html"
+ FileUtils.rm_rf "spec/test_htmlimages"
+ IsoDoc::HtmlConvert.new({htmlstylesheet: "spec/assets/html.scss", datauriimage: true}).convert("spec/test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <figure id="_">
+ <name>Split-it-right sample divider</name>
+ <image src="#{File.expand_path(File.join(File.dirname(__FILE__), "..", "assets/rice_image1.png"))}" id="_" mimetype="image/png"/>
+ <image src="assets/rice_image1.png" id="_" mimetype="image/png"/>
+ </figure>
+ </foreword></preface>
+ </iso-standard>
INPUT
- html = File.read('spec/test.html').sub(/^.*<main class="main-section">/m, '<main class="main-section">')
- .sub(%r{</main>.*$}m, '</main>')
+ html = File.read("spec/test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
+ sub(%r{</main>.*$}m, "</main>")
expect(xmlpp(html.gsub(%r{src="data:image/png;base64,[^"]+"}, %{src="data:image/png;base64,_"}))).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
- <br />
- <div>
- <h1 class="ForewordTitle">Foreword</h1>
- <div id="_" class="figure">
- <img src="data:image/png;base64,_" height="776" width="922" />
- <img src="data:image/png;base64,_" height="776" width="922" />
- <p class="FigureTitle" style="text-align:center;">Figure 1 — Split-it-right sample divider</p></div>
- </div>
- <p class="zzSTDTitle1"></p>
- </main>
+ <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
+ <br />
+ <div>
+ <h1 class="ForewordTitle">Foreword</h1>
+ <div id="_" class="figure">
+ <img src="data:image/png;base64,_" height="776" width="922" />
+ <img src="data:image/png;base64,_" height="776" width="922" />
+ <p class="FigureTitle" style="text-align:center;">Split-it-right sample divider</p></div>
+ </div>
+ <p class="zzSTDTitle1"></p>
+ </main>
OUTPUT
+
end
- it 'processes IsoXML terms for HTML' do
- FileUtils.rm_f 'test.html'
- FileUtils.rm_f 'test.doc'
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <sections>
- <terms id="_terms_and_definitions" obligation="normative"><title>Terms and Definitions</title>
- <term id="paddy1"><preferred>paddy</preferred>
- <domain>rice</domain>
- <definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
- <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f892">
- <p id="_65c9a509-9a89-4b54-a890-274126aeb55c">Foreign seeds, husks, bran, sand, dust.</p>
- <ul>
- <li>A</li>
- </ul>
- </termexample>
- <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f894">
- <ul>
- <li>A</li>
- </ul>
- </termexample>
-
- <termsource status="modified">
- <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011"><locality type="clause"><referenceFrom>3.1</referenceFrom></locality></origin>
- <modification>
- <p id="_e73a417d-ad39-417d-a4c8-20e4e2529489">The term "cargo rice" is shown as deprecated, and Note 1 to entry is not included here</p>
- </modification>
- </termsource></term>
-
- <term id="paddy"><preferred>paddy</preferred><admitted>paddy rice</admitted>
- <admitted>rough rice</admitted>
- <deprecates>cargo rice</deprecates>
- <definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
- <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f893">
- <ul>
- <li>A</li>
- </ul>
- </termexample>
- <termnote id="_671a1994-4783-40d0-bc81-987d06ffb74e">
- <p id="_19830f33-e46c-42cc-94ca-a5ef101132d5">The starch of waxy rice consists almost entirely of amylopectin. The kernels have a tendency to stick together after cooking.</p>
- </termnote>
- <termnote id="_671a1994-4783-40d0-bc81-987d06ffb74f">
- <ul><li>A</li></ul>
- <p id="_19830f33-e46c-42cc-94ca-a5ef101132d5">The starch of waxy rice consists almost entirely of amylopectin. The kernels have a tendency to stick together after cooking.</p>
- </termnote>
- <termsource status="identical">
- <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011"><locality type="clause"><referenceFrom>3.1</referenceFrom></locality></origin>
- </termsource></term>
- </terms>
- </sections>
- </iso-standard>
+ it "processes IsoXML terms for HTML" do
+ FileUtils.rm_f "test.html"
+ FileUtils.rm_f "test.doc"
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <sections>
+ <terms id="_terms_and_definitions" obligation="normative"><title>Terms and Definitions</title>
+<term id="paddy1"><name>1.1.</name><preferred>paddy</preferred>
+<domain>rice</domain>
+<definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
+<termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f892">
+ <p id="_65c9a509-9a89-4b54-a890-274126aeb55c">Foreign seeds, husks, bran, sand, dust.</p>
+ <ul>
+ <li>A</li>
+ </ul>
+</termexample>
+<termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f894">
+ <ul>
+ <li>A</li>
+ </ul>
+</termexample>
+<termsource status="modified">
+ <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011"><locality type="clause"><referenceFrom>3.1</referenceFrom></locality></origin>
+ <modification>
+ <p id="_e73a417d-ad39-417d-a4c8-20e4e2529489">The term "cargo rice" is shown as deprecated, and Note 1 to entry is not included here</p>
+ </modification>
+</termsource></term>
+<term id="paddy"><name>1.2.</name><preferred>paddy</preferred><admitted>paddy rice</admitted>
+<admitted>rough rice</admitted>
+<deprecates>cargo rice</deprecates>
+<definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
+<termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f893">
+ <ul>
+ <li>A</li>
+ </ul>
+</termexample>
+<termnote id="_671a1994-4783-40d0-bc81-987d06ffb74e">
+ <p id="_19830f33-e46c-42cc-94ca-a5ef101132d5">The starch of waxy rice consists almost entirely of amylopectin. The kernels have a tendency to stick together after cooking.</p>
+</termnote>
+<termnote id="_671a1994-4783-40d0-bc81-987d06ffb74f">
+<ul><li>A</li></ul>
+ <p id="_19830f33-e46c-42cc-94ca-a5ef101132d5">The starch of waxy rice consists almost entirely of amylopectin. The kernels have a tendency to stick together after cooking.</p>
+</termnote>
+<termsource status="identical">
+ <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011"><locality type="clause"><referenceFrom>3.1</referenceFrom></locality></origin>
+</termsource></term>
+</terms>
+</sections>
+</iso-standard>
INPUT
- expect(File.exist?('test.html')).to be true
- html = File.read('test.html')
+ expect(File.exist?("test.html")).to be true
+ html = File.read("test.html")
expect(html).to match(%r{<h2 class="TermNum" id="paddy1">1\.1\.</h2>})
expect(html).to match(%r{<h2 class="TermNum" id="paddy">1\.2\.</h2>})
end
- it 'processes empty term modifications' do
- FileUtils.rm_f 'test.html'
- FileUtils.rm_f 'test.doc'
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <sections>
- <terms id="_terms_and_definitions" obligation="normative"><title>Terms and Definitions</title>
- <term id="paddy1"><preferred>paddy</preferred>
- <domain>rice</domain>
- <definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
- <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f892">
- <p id="_65c9a509-9a89-4b54-a890-274126aeb55c">Foreign seeds, husks, bran, sand, dust.</p>
- <ul>
- <li>A</li>
- </ul>
- </termexample>
- <termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f894">
- <ul>
- <li>A</li>
- </ul>
- </termexample>
- <termsource status="modified">
- <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011"><locality type="clause"><referenceFrom>3.1</referenceFrom></locality></origin>
- <modification>
- <p id="_e73a417d-ad39-417d-a4c8-20e4e2529489"/>
- </modification>
- </termsource></term>
- </terms>
- </sections>
- </iso-standard>
+ it "processes empty term modifications" do
+ FileUtils.rm_f "test.html"
+ FileUtils.rm_f "test.doc"
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <sections>
+ <terms id="_terms_and_definitions" obligation="normative"><title>Terms and Definitions</title>
+<term id="paddy1"><preferred>paddy</preferred>
+<domain>rice</domain>
+<definition><p id="_eb29b35e-123e-4d1c-b50b-2714d41e747f">rice retaining its husk after threshing</p></definition>
+<termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f892">
+ <p id="_65c9a509-9a89-4b54-a890-274126aeb55c">Foreign seeds, husks, bran, sand, dust.</p>
+ <ul>
+ <li>A</li>
+ </ul>
+</termexample>
+<termexample id="_bd57bbf1-f948-4bae-b0ce-73c00431f894">
+ <ul>
+ <li>A</li>
+ </ul>
+</termexample>
+<termsource status="modified">
+ <origin bibitemid="ISO7301" type="inline" citeas="ISO 7301:2011">ISO 7301:2011, Clause 3.1</origin>
+ <modification>
+ <p id="_e73a417d-ad39-417d-a4c8-20e4e2529489"/>
+ </modification>
+</termsource></term>
+</terms>
+</sections>
+</iso-standard>
INPUT
- expect(File.exist?('test.html')).to be true
- html = File.read('test.html')
+ expect(File.exist?("test.html")).to be true
+ html = File.read("test.html")
expect(html).to include '[SOURCE: <a href="#ISO7301">ISO 7301:2011, Clause 3.1</a>, modified]'
end
- it 'creates continuation styles for multiparagraph list items in Word' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <ul>
- <li><p>A</p>
- <p>B</p></li>
- <li><ol><li><p>C</p>
- <p>D</p>
- <sourcecode>E</sourcecode></li>
- </ol></li>
- </ul>
- <ol>
- <li><p>A1</p>
- <p>B1</p></li>
- <li><ul><li><p>C1</p>
- <formula id="_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62">
- <stem type="AsciiMath">D1</stem>
- </formula>
- </ul></li>
- </ol>
- </foreword></preface>
- </iso-standard>
+
+ it "creates continuation styles for multiparagraph list items in Word" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <ul>
+ <li><p>A</p>
+ <p>B</p></li>
+ <li><ol><li><p>C</p>
+ <p>D</p>
+ <sourcecode>E</sourcecode></li>
+ </ol></li>
+ </ul>
+ <ol>
+ <li><p>A1</p>
+ <p>B1</p></li>
+ <li><ul><li><p>C1</p>
+ <formula id="_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62">
+ <stem type="AsciiMath">D1</stem>
+ </formula>
+ </ul></li>
+ </ol>
+ </foreword></preface>
+ </iso-standard>
INPUT
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">')
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">').
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <div class='WordSection2' xmlns:m='m'>
- <p class='MsoNormal'>
- <br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
+ <div class='WordSection2' xmlns:m='m'>
+ <p class='MsoNormal'>
+ <br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
+ </p>
+ <div>
+ <h1 class='ForewordTitle'>Foreword</h1>
+ <p class='MsoListParagraphCxSpFirst'>
+ A
+ <div class='ListContLevel1'>
+ <p class='MsoNormal'>B</p>
+ </div>
</p>
- <div>
- <h1 class='ForewordTitle'>Foreword</h1>
+ <p class='MsoListParagraphCxSpLast'>
<p class='MsoListParagraphCxSpFirst'>
- A
- <div class='ListContLevel1'>
- <p class='MsoNormal'>B</p>
+ C
+ <div class='ListContLevel2'>
+ <p class='MsoNormal'>D</p>
</div>
- </p>
- <p class='MsoListParagraphCxSpLast'>
- <p class='MsoListParagraphCxSpFirst'>
- C
- <div class='ListContLevel2'>
- <p class='MsoNormal'>D</p>
- </div>
- <div class='ListContLevel2'>
- <p class='Sourcecode'>E</p>
- </div>
- </p>
- </p>
- <p class='MsoListParagraphCxSpFirst'>
- A1
- <div class='ListContLevel1'>
- <p class='MsoNormal'>B1</p>
+ <div class='ListContLevel2'>
+ <p class='Sourcecode'>E</p>
</div>
</p>
- <p class='MsoListParagraphCxSpLast'>
- C1
- <div class='ListContLevel2'>
- <div>
- <a name='_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62' id='_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62'/>
- <div class='formula'>
- <p class='MsoNormal'>
- <span class='stem'>
- <m:oMath>
- <m:r>
- <m:t>D1</m:t>
- </m:r>
- </m:oMath>
- </span>
- <span style='mso-tab-count:1'>  </span>
- (1)
- </p>
- </div>
+ </p>
+ <p class='MsoListParagraphCxSpFirst'>
+ A1
+ <div class='ListContLevel1'>
+ <p class='MsoNormal'>B1</p>
+ </div>
+ </p>
+ <p class='MsoListParagraphCxSpLast'>
+ C1
+ <div class='ListContLevel2'>
+ <div>
+ <a name='_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62' id='_5fc1ef0f-75d2-4b54-802c-b1bad4a53b62'/>
+ <div class='formula'>
+ <p class='MsoNormal'>
+ <span class='stem'>
+ <m:oMath>
+ <m:r>
+ <m:t>D1</m:t>
+ </m:r>
+ </m:oMath>
+ </span>
+ </p>
</div>
</div>
- </p>
- </div>
- <p class='MsoNormal'> </p>
+ </div>
+ </p>
</div>
+ <p class='MsoNormal'> </p>
+ </div>
OUTPUT
end
- it 'does not lose HTML escapes in postprocessing' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <sourcecode id="samplecode">
- <name>XML code</name>
- <xml> &
- </sourcecode>
- </foreword></preface>
- </iso-standard>
+ it "does not lose HTML escapes in postprocessing" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <sourcecode id="samplecode">
+ <name>XML code</name>
+ <xml> &
+</sourcecode>
+ </foreword></preface>
+ </iso-standard>
INPUT
- html = File.read('test.html').sub(/^.*<main class="main-section">/m, '<main class="main-section">')
- .sub(%r{</main>.*$}m, '</main>')
+ html = File.read("test.html").sub(/^.*<main class="main-section">/m, '<main class="main-section">').
+ sub(%r{</main>.*$}m, "</main>")
expect(xmlpp(html)).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
- <br />
- <div>
- <h1 class="ForewordTitle">Foreword</h1>
- <pre id="samplecode" class="prettyprint "><br />    <br />  <xml> &<br />
- </pre>
- <p class="SourceTitle" style="text-align:center;">Figure 1 — XML code</p>
- </div>
- <p class="zzSTDTitle1"></p>
- </main>
+ <main class="main-section"><button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
+ <br />
+ <div>
+ <h1 class="ForewordTitle">Foreword</h1>
+ <pre id="samplecode" class="prettyprint "><br />    <br />  <xml> &<br />
+ </pre>
+ <p class="SourceTitle" style="text-align:center;">XML code</p>
+ </div>
+ <p class="zzSTDTitle1"></p>
+ </main>
OUTPUT
end
- it 'does not lose HTML escapes in postprocessing (Word)' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <sourcecode id="samplecode">
- <name>XML code</name>
- <xml> &
- </sourcecode>
- </foreword></preface>
- </iso-standard>
+
+ it "does not lose HTML escapes in postprocessing (Word)" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <sourcecode id="samplecode">
+ <name>XML code</name>
+ <xml> &
+</sourcecode>
+ </foreword></preface>
+ </iso-standard>
INPUT
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">')
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">').
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <div class="WordSection2">
- <p class="MsoNormal">
- <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
- </p>
- <div>
- <h1 class="ForewordTitle">Foreword</h1>
- <p class="Sourcecode" style="page-break-after:avoid;"><a name="samplecode" id="samplecode"></a><br/>    <br/>  <xml> &<br/></p><p class="SourceTitle" style="text-align:center;">Figure 1 — XML code</p>
- </div>
- <p class="MsoNormal"> </p>
+ <div class="WordSection2">
+ <p class="MsoNormal">
+ <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
+ </p>
+ <div>
+ <h1 class="ForewordTitle">Foreword</h1>
+ <p class="Sourcecode" style="page-break-after:avoid;"><a name="samplecode" id="samplecode"></a><br/>    <br/>  <xml> &<br/></p><p class="SourceTitle" style="text-align:center;">XML code</p>
</div>
-
+ <p class="MsoNormal"> </p>
+ </div>
OUTPUT
end
- it 'propagates example style to paragraphs in postprocessing (Word)' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <example id="samplecode">
- <p>ABC</p>
- </example>
- </foreword></preface>
- </iso-standard>
+ it "propagates example style to paragraphs in postprocessing (Word)" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+ <example id="samplecode">
+ <p>ABC</p>
+</example>
+ </foreword></preface>
+ </iso-standard>
INPUT
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">')
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">').
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "")
expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <div class="WordSection2">
- <p class="MsoNormal">
- <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
- </p>
- <div>
- <h1 class="ForewordTitle">Foreword</h1>
- <div class="example"><a name="samplecode" id="samplecode"></a><p class="example-title">EXAMPLE</p>
- <p class="example">ABC</p>
+<div class="WordSection2">
+ <p class="MsoNormal">
+ <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
+ </p>
+ <div>
+ <h1 class="ForewordTitle">Foreword</h1>
+ <div class="example"><a name="samplecode" id="samplecode"></a>
+ <p class="example">ABC</p>
+ </div>
</div>
- </div>
- <p class="MsoNormal"> </p>
- </div>
+ <p class="MsoNormal"> </p>
+ </div>
OUTPUT
end
- it 'deals with image captions (Word)' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <figure id="fig1">
- <name>Typical arrangement of the far-field scan set-up</name>
- <image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
- </figure>
- </foreword></preface>
- </iso-standard>
+ it "deals with image captions (Word)" do
+FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+<figure id="fig1">
+ <name>Typical arrangement of the far-field scan set-up</name>
+ <image src="spec/assets/rice_image1.png" id="_" mimetype="image/png"/>
+ </figure>
+ </foreword></preface>
+ </iso-standard>
INPUT
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">')
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
- .sub(/src="[^"]+"/, 'src="_"')
+ word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2">').
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "").
+ sub(/src="[^"]+"/, 'src="_"')
expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <div class="WordSection2">
- <p class="MsoNormal">
- <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
- </p>
- <div>
- <h1 class="ForewordTitle">Foreword</h1>
- <div class="figure"><a name="fig1" id="fig1"></a>
- <p style="page-break-after:avoid;" class="figure"><img src="_" width="400" height="337"/></p>
- <p class="FigureTitle" style="text-align:center;">Figure 1 — Typical arrangement of the far-field scan set-up</p></div>
- </div>
- <p class="MsoNormal"> </p>
+ <div class="WordSection2">
+ <p class="MsoNormal">
+ <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
+ </p>
+ <div>
+ <h1 class="ForewordTitle">Foreword</h1>
+ <div class="figure"><a name="fig1" id="fig1"></a>
+ <p style="page-break-after:avoid;" class="figure"><img src="_" width="400" height="337"/></p>
+ <p class="FigureTitle" style="text-align:center;">Typical arrangement of the far-field scan set-up</p></div>
</div>
+ <p class="MsoNormal"> </p>
+ </div>
OUTPUT
+
end
- it 'deals with empty table titles (Word)' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <table id="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7" unnumbered="true"><thead><tr>
- <td rowspan="2">
- <p id="_c47d9b39-adb2-431d-9320-78cb148fdb56">Output wavelength <stem type="MathML"><math xmlns="http://www.w3.org/1998/Math/MathML"><mrow><mo>(</mo><mi>μ</mi><mi>m</mi><mo>)</mo></mrow></math></stem></p>
- </td>
- <th colspan="3" align="left">Predictive wavelengths</th>
- </tr>
- </thead>
- </table>
- </preface>
- </iso-standard>
+ it "deals with empty table titles (Word)" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+<table id="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7" unnumbered="true"><thead><tr>
+ <td rowspan="2">
+ <p id="_c47d9b39-adb2-431d-9320-78cb148fdb56">Output wavelength <stem type="MathML"><math xmlns="http://www.w3.org/1998/Math/MathML"><mrow><mo>(</mo><mi>μ</mi><mi>m</mi><mo>)</mo></mrow></math></stem></p>
+ </td>
+ <th colspan="3" align="left">Predictive wavelengths</th>
+ </tr>
+ </thead>
+ </table>
+ </preface>
+ </iso-standard>
INPUT
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">')
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
- .sub(/src="[^"]+"/, 'src="_"')
+word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">').
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "").
+ sub(/src="[^"]+"/, 'src="_"')
expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <div class="WordSection2" xmlns:m="m">
- <p class="MsoNormal">
- <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
- </p>
- <div>
- <h1 class="ForewordTitle">Foreword</h1>
- <div align="center" class="table_container">
- <table class="MsoISOTable" style="mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;"><a name="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7" id="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7"></a>
- <thead>
- <tr>
- <td rowspan="2" style="border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.0pt;mso-border-bottom-alt:solid windowtext 1.0pt;">
- <p class="MsoNormal"><a name="_c47d9b39-adb2-431d-9320-78cb148fdb56" id="_c47d9b39-adb2-431d-9320-78cb148fdb56"></a>Output wavelength <span class="stem"><m:oMath>
- <m:r><m:t>(μm)</m:t></m:r>
- </m:oMath>
- </span></p>
- </td>
- <th colspan="3" align="left" style="font-weight:bold;border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;">Predictive wavelengths</th>
- </tr>
- </thead>
- </table>
- </div>
- </div>
- <p class="MsoNormal"> </p>
- </div>
+ <div class="WordSection2" xmlns:m="m">
+ <p class="MsoNormal">
+ <br clear="all" style="mso-special-character:line-break;page-break-before:always"/>
+ </p>
+ <div>
+ <h1 class="ForewordTitle">Foreword</h1>
+ <div align="center" class="table_container">
+ <table class="MsoISOTable" style="mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;"><a name="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7" id="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7"></a>
+ <thead>
+ <tr>
+ <td rowspan="2" style="border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.0pt;mso-border-bottom-alt:solid windowtext 1.0pt;">
+ <p class="MsoNormal"><a name="_c47d9b39-adb2-431d-9320-78cb148fdb56" id="_c47d9b39-adb2-431d-9320-78cb148fdb56"></a>Output wavelength <span class="stem"><m:oMath>
+ <m:r><m:t>(μm)</m:t></m:r>
+ </m:oMath>
+ </span></p>
+ </td>
+ <th colspan="3" align="left" style="font-weight:bold;border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;">Predictive wavelengths</th>
+ </tr>
+ </thead>
+ </table>
+ </div>
+ </div>
+ <p class="MsoNormal"> </p>
+ </div>
OUTPUT
end
- it 'propagates alignment of table cells (Word)' do
- FileUtils.rm_f 'test.doc'
- FileUtils.rm_f 'test.html'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss').convert('test', <<~"INPUT", false)
- <iso-standard xmlns="http://riboseinc.com/isoxml">
- <preface><foreword>
- <table id="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7" unnumbered="true"><thead><tr>
- <td rowspan="2" align="left">
- <p id="_c47d9b39-adb2-431d-9320-78cb148fdb56">Output wavelength</p>
- <p id="_c47d9b39-adb2-431d-9320-78cb148fdb57">Output wavelength</p>
- </td>
- <th colspan="3" align="right"><p id="_c47d9b39-adb2-431d-9320-78cb148fdb58">Predictive wavelengths</p></th>
- </tr>
- </thead>
- </table>
- </preface>
- </iso-standard>
+ it "propagates alignment of table cells (Word)" do
+ FileUtils.rm_f "test.doc"
+ FileUtils.rm_f "test.html"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss"}).convert("test", <<~"INPUT", false)
+ <iso-standard xmlns="http://riboseinc.com/isoxml">
+ <preface><foreword>
+<table id="_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7" unnumbered="true"><thead><tr>
+ <td rowspan="2" align="left">
+ <p id="_c47d9b39-adb2-431d-9320-78cb148fdb56">Output wavelength</p>
+ <p id="_c47d9b39-adb2-431d-9320-78cb148fdb57">Output wavelength</p>
+ </td>
+ <th colspan="3" align="right"><p id="_c47d9b39-adb2-431d-9320-78cb148fdb58">Predictive wavelengths</p></th>
+ </tr>
+ </thead>
+ </table>
+ </preface>
+ </iso-standard>
INPUT
- word = File.read('test.doc').sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">')
- .sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, '')
- .sub(/src="[^"]+"/, 'src="_"')
+word = File.read("test.doc").sub(/^.*<div class="WordSection2">/m, '<div class="WordSection2" xmlns:m="m">').
+ sub(%r{<p class="MsoNormal">\s*<br clear="all" class="section"/>\s*</p>\s*<div class="WordSection3">.*$}m, "").
+ sub(/src="[^"]+"/, 'src="_"')
expect(xmlpp(word)).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <div class='WordSection2' xmlns:m='m'>
- <p class='MsoNormal'>
- <br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
- </p>
- <div>
- <h1 class='ForewordTitle'>Foreword</h1>
- <div align='center' class="table_container">
- <table class='MsoISOTable' style='mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
- <a name='_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7' id='_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7'/>
- <thead>
- <tr>
- <td rowspan='2' align='left' style='border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.0pt;mso-border-bottom-alt:solid windowtext 1.0pt;'>
- <p style='text-align: left' class='MsoNormal'>
- <a name='_c47d9b39-adb2-431d-9320-78cb148fdb56' id='_c47d9b39-adb2-431d-9320-78cb148fdb56'/>
- Output wavelength
- </p>
- <p style='text-align: left' class='MsoNormal'>
- <a name='_c47d9b39-adb2-431d-9320-78cb148fdb57' id='_c47d9b39-adb2-431d-9320-78cb148fdb57'/>
- Output wavelength
- </p>
- </td>
- <th colspan='3' align='right' style='font-weight:bold;border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>
- <p style='text-align: right' class='MsoNormal'>
- <a name='_c47d9b39-adb2-431d-9320-78cb148fdb58' id='_c47d9b39-adb2-431d-9320-78cb148fdb58'/>
- Predictive wavelengths
- </p>
- </th>
- </tr>
- </thead>
- </table>
- </div>
+ <div class='WordSection2' xmlns:m='m'>
+ <p class='MsoNormal'>
+ <br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
+ </p>
+ <div>
+ <h1 class='ForewordTitle'>Foreword</h1>
+ <div align='center' class="table_container">
+ <table class='MsoISOTable' style='mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
+ <a name='_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7' id='_fe12b8f8-6858-4cd6-af7d-d4b6f3ebd1a7'/>
+ <thead>
+ <tr>
+ <td rowspan='2' align='left' style='border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.0pt;mso-border-bottom-alt:solid windowtext 1.0pt;'>
+ <p style='text-align: left' class='MsoNormal'>
+ <a name='_c47d9b39-adb2-431d-9320-78cb148fdb56' id='_c47d9b39-adb2-431d-9320-78cb148fdb56'/>
+ Output wavelength
+ </p>
+ <p style='text-align: left' class='MsoNormal'>
+ <a name='_c47d9b39-adb2-431d-9320-78cb148fdb57' id='_c47d9b39-adb2-431d-9320-78cb148fdb57'/>
+ Output wavelength
+ </p>
+ </td>
+ <th colspan='3' align='right' style='font-weight:bold;border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>
+ <p style='text-align: right' class='MsoNormal'>
+ <a name='_c47d9b39-adb2-431d-9320-78cb148fdb58' id='_c47d9b39-adb2-431d-9320-78cb148fdb58'/>
+ Predictive wavelengths
+ </p>
+ </th>
+ </tr>
+ </thead>
+ </table>
</div>
- <p class='MsoNormal'> </p>
</div>
+ <p class='MsoNormal'> </p>
+ </div>
OUTPUT
- end
+ end
- it 'cleans up boilerplate' do
- expect(xmlpp(IsoDoc::HtmlConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', filename: 'test').html_preface(Nokogiri::XML(<<~INPUT)).to_xml).sub(/^.*<main/m, '<main').sub(%r{</main>.*$}m, '</main>')).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <html>
- <head/>
- <body>
- <div class="main-section">
- <div id="boilerplate-copyright"> <h1>Copyright</h1> </div>
- <div id="boilerplate-license"> <h1>License</h1> </div>
- <div id="boilerplate-legal"> <h1>Legal</h1> </div>
- <div id="boilerplate-feedback"> <h1>Feedback</h1> </div>
+ it "cleans up boilerplate" do
+ expect(xmlpp(IsoDoc::HtmlConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", filename: "test"}).html_preface(Nokogiri::XML(<<~INPUT)).to_xml).sub(/^.*<main/m, "<main").sub(%r{</main>.*$}m, "</main>")).to be_equivalent_to xmlpp(<<~"OUTPUT")
+ <html>
+ <head/>
+ <body>
+ <div class="main-section">
+ <div id="boilerplate-copyright"> <h1>Copyright</h1> </div>
+ <div id="boilerplate-license"> <h1>License</h1> </div>
+ <div id="boilerplate-legal"> <h1>Legal</h1> </div>
+ <div id="boilerplate-feedback"> <h1>Feedback</h1> </div>
+ <hr/>
+ <div id="boilerplate-feedback-destination"/>
+ <div id="boilerplate-legal-destination"/>
+ <div id="boilerplate-license-destination"/>
+ <div id="boilerplate-copyright-destination"/>
+ </div>
+ </body>
+ </html>
+ INPUT
+ <main class='main-section'>
+ <button onclick='topFunction()' id='myBtn' title='Go to top'>Top</button>
<hr/>
- <div id="boilerplate-feedback-destination"/>
- <div id="boilerplate-legal-destination"/>
- <div id="boilerplate-license-destination"/>
- <div id="boilerplate-copyright-destination"/>
+ <div id='boilerplate-feedback'>
+ <h1 class='IntroTitle'>Feedback</h1>
</div>
- </body>
- </html>
- INPUT
- <main class='main-section'>
- <button onclick='topFunction()' id='myBtn' title='Go to top'>Top</button>
- <hr/>
- <div id='boilerplate-feedback'>
- <h1 class='IntroTitle'>Feedback</h1>
- </div>
- <div id='boilerplate-legal'>
- <h1 class='IntroTitle'>Legal</h1>
- </div>
- <div id='boilerplate-license'>
- <h1 class='IntroTitle'>License</h1>
- </div>
- <div id='boilerplate-copyright'>
- <h1 class='IntroTitle'>Copyright</h1>
- </div>
- </main>
+ <div id='boilerplate-legal'>
+ <h1 class='IntroTitle'>Legal</h1>
+ </div>
+ <div id='boilerplate-license'>
+ <h1 class='IntroTitle'>License</h1>
+ </div>
+ <div id='boilerplate-copyright'>
+ <h1 class='IntroTitle'>Copyright</h1>
+ </div>
+ </main>
OUTPUT
end
- it 'cleans up boilerplate (Word)' do
- expect(xmlpp(IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', filename: 'test').word_cleanup(Nokogiri::XML(<<~INPUT)).to_xml).sub(/^.*<main/m, '<main').sub(%r{</main>.*$}m, '</main>')).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <html>
- <head/>
- <body>
- <div class="main-section">
- <div id="boilerplate-copyright"> <h1>Copyright</h1> </div>
- <div id="boilerplate-license"> <h1>License</h1> </div>
- <div id="boilerplate-legal"> <h1>Legal</h1> </div>
- <div id="boilerplate-feedback"> <h1>Feedback</h1> </div>
+ it "cleans up boilerplate (Word)" do
+ expect(xmlpp(IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", filename: "test"}).word_cleanup(Nokogiri::XML(<<~INPUT)).to_xml).sub(/^.*<main/m, "<main").sub(%r{</main>.*$}m, "</main>")).to be_equivalent_to xmlpp(<<~"OUTPUT")
+ <html>
+ <head/>
+ <body>
+ <div class="main-section">
+ <div id="boilerplate-copyright"> <h1>Copyright</h1> </div>
+ <div id="boilerplate-license"> <h1>License</h1> </div>
+ <div id="boilerplate-legal"> <h1>Legal</h1> </div>
+ <div id="boilerplate-feedback"> <h1>Feedback</h1> </div>
+ <hr/>
+ <div id="boilerplate-feedback-destination"/>
+ <div id="boilerplate-legal-destination"/>
+ <div id="boilerplate-license-destination"/>
+ <div id="boilerplate-copyright-destination"/>
+ </div>
+ </body>
+ </html>
+ INPUT
+ <html>
+ <head/>
+ <body>
+ <div class='main-section'>
<hr/>
- <div id="boilerplate-feedback-destination"/>
- <div id="boilerplate-legal-destination"/>
- <div id="boilerplate-license-destination"/>
- <div id="boilerplate-copyright-destination"/>
+ <div id='boilerplate-feedback'>
+ <p class='TitlePageSubhead'>Feedback</p>
</div>
- </body>
- </html>
- INPUT
- <html>
- <head/>
- <body>
- <div class='main-section'>
- <hr/>
- <div id='boilerplate-feedback'>
- <p class='TitlePageSubhead'>Feedback</p>
- </div>
- <div id='boilerplate-legal'>
- <p class='TitlePageSubhead'>Legal</p>
- </div>
- <div id='boilerplate-license'>
- <p class='TitlePageSubhead'>License</p>
- </div>
- <div id='boilerplate-copyright'>
- <p class='TitlePageSubhead'>Copyright</p>
- </div>
- </div>
- </body>
- </html>
+ <div id='boilerplate-legal'>
+ <p class='TitlePageSubhead'>Legal</p>
+ </div>
+ <div id='boilerplate-license'>
+ <p class='TitlePageSubhead'>License</p>
+ </div>
+ <div id='boilerplate-copyright'>
+ <p class='TitlePageSubhead'>Copyright</p>
+ </div>
+ </div>
+ </body>
+</html>
OUTPUT
end
- it 'deals with landscape and portrait pagebreaks (Word)' do
- FileUtils.rm_f 'test.doc'
- IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', filename: 'test').convert('test', <<~"INPUT", false)
- <standard-document xmlns="http://riboseinc.com/isoxml">
- <bibdata type="standard">
- <title language="en" format="text/plain">Document title</title>
- <version>
- <draft>1.2</draft>
- </version>
- <language>en</language>
- <script>Latn</script>
- <status><stage>published</stage></status>
- <ext>
- <doctype>article</doctype>
- </ext>
- </bibdata>
- <preface>
- <introduction><title>Preface 1</title>
- <p align="center">This is a <pagebreak orientation="landscape"/> paragraph</p>
- <table>
- <tbody>
- <tr><td>A</td><td>B</td></tr>
- </tbody>
- </table>
- <clause><title>Preface 1.1</title>
- <p>On my side</p>
- <pagebreak orientation="portrait"/>
- <p>Upright again</p>
- </clause>
- <clause><title>Preface 1.3</title>
- <p>And still upright</p>
- </clause>
- </introduction>
- </preface>
- <sections><clause><title>Foreword</title>
- <note>
- <p id="_">For further information on the Foreword, see <strong>ISO/IEC Directives, Part 2, 2016, Clause 12.</strong></p>
- <pagebreak orientation="landscape"/>
- <table id="_c09a7e60-b0c7-4418-9bfc-2ef0bc09a249">
- <thead>
- <tr>
- <th align="left">A</th>
- <th align="left">B</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td align="left">C</td>
- <td align="left">D</td>
- </tr>
- </tbody>
- <note id="_8fff1596-290e-4314-b03c-7a8aab97eebe">
- <p id="_32c22439-387a-48cf-a006-5ab3b934ba73">B</p>
- </note></table>
- <pagebreak orientation="portrait"/>
- <p>And up</p>
- </note>
- <pagebreak orientation="portrait"/>
- </clause></sections>
- <annex id="_level_1" inline-header="false" obligation="normative">
- <title>Annex 1</title>
- </annex>
- </standard-document>
+ it "deals with landscape and portrait pagebreaks (Word)" do
+ FileUtils.rm_f "test.doc"
+ IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", filename: "test"}).convert("test", <<~"INPUT", false)
+ <standard-document xmlns="http://riboseinc.com/isoxml">
+ <bibdata type="standard">
+ <title language="en" format="text/plain">Document title</title>
+ <version>
+ <draft>1.2</draft>
+ </version>
+ <language>en</language>
+ <script>Latn</script>
+ <status><stage>published</stage></status>
+ <ext>
+ <doctype>article</doctype>
+ </ext>
+ </bibdata>
+ <preface>
+ <introduction><title>Preface 1</title>
+ <p align="center">This is a <pagebreak orientation="landscape"/> paragraph</p>
+ <table>
+ <tbody>
+ <tr><td>A</td><td>B</td></tr>
+ </tbody>
+ </table>
+ <clause><title>Preface 1.1</title>
+ <p>On my side</p>
+ <pagebreak orientation="portrait"/>
+ <p>Upright again</p>
+ </clause>
+ <clause><title>Preface 1.3</title>
+ <p>And still upright</p>
+ </clause>
+ </introduction>
+ </preface>
+ <sections><clause><title>Foreword</title>
+ <note>
+ <p id="_">For further information on the Foreword, see <strong>ISO/IEC Directives, Part 2, 2016, Clause 12.</strong></p>
+ <pagebreak orientation="landscape"/>
+ <table id="_c09a7e60-b0c7-4418-9bfc-2ef0bc09a249">
+<thead>
+<tr>
+<th align="left">A</th>
+<th align="left">B</th>
+</tr>
+</thead>
+<tbody>
+<tr>
+<td align="left">C</td>
+<td align="left">D</td>
+</tr>
+</tbody>
+<note id="_8fff1596-290e-4314-b03c-7a8aab97eebe">
+<p id="_32c22439-387a-48cf-a006-5ab3b934ba73">B</p>
+</note></table>
+ <pagebreak orientation="portrait"/>
+ <p>And up</p>
+ </note>
+ <pagebreak orientation="portrait"/>
+ </clause></sections>
+ <annex id="_level_1" inline-header="false" obligation="normative">
+ <title>Annex 1</title>
+ </annex>
+ </standard-document>
INPUT
- expect(File.exist?('test.doc')).to be true
- html = File.read('test.doc', encoding: 'UTF-8')
- expect(html).to include 'div.WordSection2_0 {page:WordSection2P;}'
- expect(html).to include 'div.WordSection2_1 {page:WordSection2L;}'
- expect(html).to include 'div.WordSection3_0 {page:WordSection3P;}'
- expect(html).to include 'div.WordSection3_1 {page:WordSection3P;}'
- expect(html).to include 'div.WordSection3_2 {page:WordSection3L;}'
+ expect(File.exist?("test.doc")).to be true
+ html = File.read("test.doc", encoding: "UTF-8")
+ expect(html).to include "div.WordSection2_0 {page:WordSection2P;}"
+expect(html).to include "div.WordSection2_1 {page:WordSection2L;}"
+ expect(html).to include "div.WordSection3_0 {page:WordSection3P;}"
+expect(html).to include "div.WordSection3_1 {page:WordSection3P;}"
+expect(html).to include "div.WordSection3_2 {page:WordSection3L;}"
- expect(xmlpp(html.sub(/^.*<body /m, '<body ').sub(%r{</body>.*$}m, '</body>'))).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <body lang='EN-US' xml:lang='EN-US' link='blue' vlink='#954F72'>
- <div class='WordSection1'>
- <p class='MsoNormal'> </p>
- </div>
+
+expect(xmlpp(html.sub(/^.*<body /m, "<body ").sub(%r{</body>.*$}m, "</body>"))).to be_equivalent_to xmlpp(<<~"OUTPUT")
+ <body lang='EN-US' xml:lang='EN-US' link='blue' vlink='#954F72'>
+ <div class='WordSection1'>
+ <p class='MsoNormal'> </p>
+ </div>
+ <p class='MsoNormal'>
+ <br clear='all' class='section'/>
+ </p>
+ <div class='WordSection2'>
+ <p class='MsoNormal'>
+ <br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
+</p>
+ <div class='Section3' id=''>
+ <h1 class='IntroTitle'>Preface 1</h1>
+ <p align='center' style='text-align:center;' class='MsoNormal'>
+ This is a
<p class='MsoNormal'>
<br clear='all' class='section'/>
</p>
- <div class='WordSection2'>
- <p class='MsoNormal'>
- <br clear='all' style='mso-special-character:line-break;page-break-before:always'/>
- </p>
- <div class='Section3' id=''>
- <h1 class='IntroTitle'>Introduction</h1>
- <p align='center' style='text-align:center;' class='MsoNormal'>
- This is a
- <p class='MsoNormal'>
- <br clear='all' class='section'/>
- </p>
- paragraph
- </p>
- </div>
- </div>
- <div class='WordSection2_1'>
- <div align='center' class='table_container'>
- <table class='MsoISOTable' style='mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
- <tbody>
- <tr>
- <td style='border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>A</td>
- <td style='border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>B</td>
- </tr>
- </tbody>
- </table>
- </div>
- <div>
- <h1>Preface 1.1</h1>
- <p class='MsoNormal'>On my side</p>
- <p class='MsoNormal'>
- <br clear='all' class='section'/>
- </p>
- </div>
- </div>
- <div class='WordSection2_0'>
- <p class='MsoNormal'>Upright again</p>
- <div>
- <h1>Preface 1.3</h1>
- <p class='MsoNormal'>And still upright</p>
- </div>
- <p class='MsoNormal'> </p>
- </div>
- <p class='MsoNormal'>
- <br clear='all' class='section'/>
- </p>
- <div class='WordSection3'>
- <p class='zzSTDTitle1'>Document title</p>
- <div>
- <h1>Foreword</h1>
- <div class='Note'>
- <p class='Note'>
- <span class='note_label'>NOTE 1</span>
- <span style='mso-tab-count:1'>  </span>
- For further information on the Foreword, see
- <b>ISO/IEC Directives, Part 2, 2016, Clause 12.</b>
- </p>
- <p class='Note'>
- <br clear='all' class='section'/>
- </p>
- </div>
- </div>
- </div>
- <div class='WordSection3_2'>
- <p class='TableTitle' style='text-align:center;'>Table 1</p>
- <div align='center' class='table_container'>
- <table class='MsoISOTable' style='mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
- <a name='_c09a7e60-b0c7-4418-9bfc-2ef0bc09a249' id='_c09a7e60-b0c7-4418-9bfc-2ef0bc09a249'/>
- <thead>
- <tr>
- <th align='left' style='font-weight:bold;border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>A</th>
- <th align='left' style='font-weight:bold;border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>B</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td align='left' style='border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>C</td>
- <td align='left' style='border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>D</td>
- </tr>
- </tbody>
- <tfoot>
- <tr>
- <td colspan='2' style='border-top:0pt;mso-border-top-alt:0pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>
- <div class='Note'>
- <a name='_8fff1596-290e-4314-b03c-7a8aab97eebe' id='_8fff1596-290e-4314-b03c-7a8aab97eebe'/>
- <p class='Note'>
- <span class='note_label'>NOTE</span>
- <span style='mso-tab-count:1'>  </span>
- B
- </p>
- </div>
- </td>
- </tr>
- </tfoot>
- </table>
- </div>
- <p class='Note'>
- <br clear='all' class='section'/>
- </p>
- </div>
- <div class='WordSection3_1'>
- <p class='Note'>And up</p>
- <p class='MsoNormal'>
+ paragraph
+ </p>
+ </div>
+ </div>
+ <div class='WordSection2_1'>
+ <div align='center' class='table_container'>
+ <table class='MsoISOTable' style='mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
+ <tbody>
+ <tr>
+ <td style='border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>A</td>
+ <td style='border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>B</td>
+ </tr>
+ </tbody>
+ </table>
+ </div>
+ <div>
+ <h2>Preface 1.1</h2>
+ <p class='MsoNormal'>On my side</p>
+ <p class='MsoNormal'>
+ <br clear='all' class='section'/>
+ </p>
+ </div>
+ </div>
+ <div class='WordSection2_0'>
+ <p class='MsoNormal'>Upright again</p>
+ <div>
+ <h2>Preface 1.3</h2>
+ <p class='MsoNormal'>And still upright</p>
+ </div>
+ <p class='MsoNormal'> </p>
+ </div>
+ <p class='MsoNormal'>
<br clear='all' class='section'/>
</p>
- </div>
- <div class='WordSection3_0'>
- <div class='Section3'>
- <a name='_level_1' id='_level_1'/>
- <h1 class='Annex'>
- <b>Annex A</b>
- <br/>
- (normative)
- <br/>
- <br/>
- <b>Annex 1</b>
- </h1>
+ <div class='WordSection3'>
+ <p class='zzSTDTitle1'>Document title</p>
+ <div>
+ <h1>Foreword</h1>
+ <div class='Note'>
+ <p class='Note'>
+ <span class='note_label'/>
+ <span style='mso-tab-count:1'>  </span>
+ For further information on the Foreword, see
+ <b>ISO/IEC Directives, Part 2, 2016, Clause 12.</b>
+ </p>
+ <p class='Note'>
+ <br clear='all' class='section'/>
+ </p>
+ </div>
+ </div>
</div>
- </div>
- <div style='mso-element:footnote-list'/>
- </body>
+ <div class='WordSection3_2'>
+ <div align='center' class='table_container'>
+ <table class='MsoISOTable' style='mso-table-anchor-horizontal:column;mso-table-overlap:never;border-spacing:0;border-width:1px;'>
+ <a name='_c09a7e60-b0c7-4418-9bfc-2ef0bc09a249' id='_c09a7e60-b0c7-4418-9bfc-2ef0bc09a249'/>
+ <thead>
+ <tr>
+ <th align='left' style='font-weight:bold;border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>A</th>
+ <th align='left' style='font-weight:bold;border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>B</th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td align='left' style='border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>C</td>
+ <td align='left' style='border-top:solid windowtext 1.5pt;mso-border-top-alt:solid windowtext 1.5pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>D</td>
+ </tr>
+ </tbody>
+ <tfoot>
+ <tr>
+ <td colspan='2' style='border-top:0pt;mso-border-top-alt:0pt;border-bottom:solid windowtext 1.5pt;mso-border-bottom-alt:solid windowtext 1.5pt;'>
+ <div class='Note'>
+ <a name='_8fff1596-290e-4314-b03c-7a8aab97eebe' id='_8fff1596-290e-4314-b03c-7a8aab97eebe'/>
+ <p class='Note'>
+ <span class='note_label'/>
+ <span style='mso-tab-count:1'>  </span>
+ B
+ </p>
+ </div>
+ </td>
+ </tr>
+ </tfoot>
+ </table>
+ </div>
+ <p class='Note'>
+ <br clear='all' class='section'/>
+ </p>
+ </div>
+ <div class='WordSection3_1'>
+ <p class='Note'>And up</p>
+ <p class='MsoNormal'>
+ <br clear='all' class='section'/>
+ </p>
+ </div>
+ <div class='WordSection3_0'>
+ <div class='Section3'>
+ <a name='_level_1' id='_level_1'/>
+ <h1 class='Annex'>Annex 1</h1>
+ </div>
+ </div>
+ <div style='mso-element:footnote-list'/>
+ </body>
OUTPUT
- end
+ end
- it 'expands out nested tables in Word' do
- expect(xmlpp(IsoDoc::WordConvert.new(wordstylesheet: 'spec/assets/word.css', htmlstylesheet: 'spec/assets/html.scss', filename: 'test').word_cleanup(Nokogiri::XML(<<~INPUT)).to_xml).sub(/^.*<main/m, '<main').sub(%r{</main>.*$}m, '</main>')).to be_equivalent_to xmlpp(<<~"OUTPUT")
- <html>
- <head/>
- <body>
- <div class="main-section">
- <table id="_7830dff8-419e-4b9e-85cf-a063689f44ca" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 1:</p></th></tr></thead><tbody><tr><td style="vertical-align:top;" class="recommend" colspan="2"><p>requirement label</p></td></tr>
-
- <table id="_a0f8c202-fd34-460c-bd5e-b2f4cc29210d" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 1-1:</p></th></tr></thead><tbody><tr style="background:#C9C9C9;"><td style="vertical-align:top;" class="recommend" colspan="2">
- <p id="_2e2c247b-ce4c-48c5-96dd-f3e090a5b4a7">Description text</p>
- </td></tr></tbody></table>
- </tbody></table>
- </div>
- <div id="_second_sample"><h2>1.2.<span style="mso-tab-count:1">  </span>Second sample</h2>
-
- <table id="_9846c486-14e5-4b1c-bb2f-55cc254dd309" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 2:</p></th></tr></thead><tbody><tr><td style="vertical-align:top;" class="recommend" colspan="2"><p>requirement label</p></td></tr><table id="_62de974c-7128-44d6-ba86-99f818f1d467" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 2-1:</p></th></tr></thead><tbody><tr style="background:#C9C9C9;"><td style="vertical-align:top;" class="recommend" colspan="2">
- <p id="_30b90b08-bd71-4497-bbcc-8c61fbb9f772">Description text</p>
- </td></tr></tbody></table>
- <table id="_fede5681-71f6-47bb-bc65-7bd0b11acd01" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 2-2:</p></th></tr></thead><tbody><tr><td style="vertical-align:top;" class="recommend" colspan="2">
- <p id="_8daa3d74-90fd-4a57-9169-de457a68cfda">Description text</p>
- </td></tr></tbody></table></tbody></table>
- </div>
- </body>
- </html>
+ it "expands out nested tables in Word" do
+ expect(xmlpp(IsoDoc::WordConvert.new({wordstylesheet: "spec/assets/word.css", htmlstylesheet: "spec/assets/html.scss", filename: "test"}).word_cleanup(Nokogiri::XML(<<~INPUT)).to_xml).sub(/^.*<main/m, "<main").sub(%r{</main>.*$}m, "</main>")).to be_equivalent_to xmlpp(<<~"OUTPUT")
+ <html>
+ <head/>
+ <body>
+ <div class="main-section">
+ <table id="_7830dff8-419e-4b9e-85cf-a063689f44ca" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 1:</p></th></tr></thead><tbody><tr><td style="vertical-align:top;" class="recommend" colspan="2"><p>requirement label</p></td></tr>
+<table id="_a0f8c202-fd34-460c-bd5e-b2f4cc29210d" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 1-1:</p></th></tr></thead><tbody><tr style="background:#C9C9C9;"><td style="vertical-align:top;" class="recommend" colspan="2">
+<p id="_2e2c247b-ce4c-48c5-96dd-f3e090a5b4a7">Description text</p>
+</td></tr></tbody></table>
+</tbody></table>
+</div>
+ <div id="_second_sample"><h2>1.2.<span style="mso-tab-count:1">  </span>Second sample</h2>
+<table id="_9846c486-14e5-4b1c-bb2f-55cc254dd309" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 2:</p></th></tr></thead><tbody><tr><td style="vertical-align:top;" class="recommend" colspan="2"><p>requirement label</p></td></tr><table id="_62de974c-7128-44d6-ba86-99f818f1d467" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 2-1:</p></th></tr></thead><tbody><tr style="background:#C9C9C9;"><td style="vertical-align:top;" class="recommend" colspan="2">
+<p id="_30b90b08-bd71-4497-bbcc-8c61fbb9f772">Description text</p>
+</td></tr></tbody></table>
+<table id="_fede5681-71f6-47bb-bc65-7bd0b11acd01" class="recommend" style="border-collapse:collapse;border-spacing:0;"><thead><tr style="background:#A5A5A5;"><th style="vertical-align:top;" class="recommend" colspan="2"><p class="RecommendationTitle">Requirement 2-2:</p></th></tr></thead><tbody><tr><td style="vertical-align:top;" class="recommend" colspan="2">
+<p id="_8daa3d74-90fd-4a57-9169-de457a68cfda">Description text</p>
+</td></tr></tbody></table></tbody></table>
+ </div>
+ </body>
+ </html>
INPUT
- <html>
- <head/>
- <body>
- <div class='main-section'>
- <table id='_7830dff8-419e-4b9e-85cf-a063689f44ca' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
- <thead>
- <tr style='background:#A5A5A5;'>
- <th style='vertical-align:top;' class='recommend' colspan='2'>
- <p class='RecommendationTitle'>Requirement 1:</p>
- </th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td style='vertical-align:top;' class='recommend' colspan='2'>
- <p>requirement label</p>
- </td>
- </tr>
- </tbody>
- </table>
- <table id='_a0f8c202-fd34-460c-bd5e-b2f4cc29210d' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
- <thead>
- <tr style='background:#A5A5A5;'>
- <th style='vertical-align:top;' class='recommend' colspan='2'>
- <p class='RecommendationTitle'>Requirement 1-1:</p>
- </th>
- </tr>
- </thead>
- <tbody>
- <tr style='background:#C9C9C9;'>
- <td style='vertical-align:top;' class='recommend' colspan='2'>
- <p id='_2e2c247b-ce4c-48c5-96dd-f3e090a5b4a7'>Description text</p>
- </td>
- </tr>
- </tbody>
- </table>
- </div>
- <div id='_second_sample'>
- <h2>
- 1.2.
- <span style='mso-tab-count:1'>  </span>
- Second sample
- </h2>
- <table id='_9846c486-14e5-4b1c-bb2f-55cc254dd309' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
- <thead>
- <tr style='background:#A5A5A5;'>
- <th style='vertical-align:top;' class='recommend' colspan='2'>
- <p class='RecommendationTitle'>Requirement 2:</p>
- </th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td style='vertical-align:top;' class='recommend' colspan='2'>
- <p>requirement label</p>
- </td>
- </tr>
- </tbody>
- </table>
- <table id='_62de974c-7128-44d6-ba86-99f818f1d467' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
- <thead>
- <tr style='background:#A5A5A5;'>
- <th style='vertical-align:top;' class='recommend' colspan='2'>
- <p class='RecommendationTitle'>Requirement 2-1:</p>
- </th>
- </tr>
- </thead>
- <tbody>
- <tr style='background:#C9C9C9;'>
- <td style='vertical-align:top;' class='recommend' colspan='2'>
- <p id='_30b90b08-bd71-4497-bbcc-8c61fbb9f772'>Description text</p>
- </td>
- </tr>
- </tbody>
- </table>
- <table id='_fede5681-71f6-47bb-bc65-7bd0b11acd01' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
- <thead>
- <tr style='background:#A5A5A5;'>
- <th style='vertical-align:top;' class='recommend' colspan='2'>
- <p class='RecommendationTitle'>Requirement 2-2:</p>
- </th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td style='vertical-align:top;' class='recommend' colspan='2'>
- <p id='_8daa3d74-90fd-4a57-9169-de457a68cfda'>Description text</p>
- </td>
- </tr>
- </tbody>
- </table>
- </div>
- </body>
- </html>
+ <html>
+ <head/>
+ <body>
+ <div class='main-section'>
+ <table id='_7830dff8-419e-4b9e-85cf-a063689f44ca' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
+ <thead>
+ <tr style='background:#A5A5A5;'>
+ <th style='vertical-align:top;' class='recommend' colspan='2'>
+ <p class='RecommendationTitle'>Requirement 1:</p>
+ </th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td style='vertical-align:top;' class='recommend' colspan='2'>
+ <p>requirement label</p>
+ </td>
+ </tr>
+ </tbody>
+ </table>
+ <table id='_a0f8c202-fd34-460c-bd5e-b2f4cc29210d' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
+ <thead>
+ <tr style='background:#A5A5A5;'>
+ <th style='vertical-align:top;' class='recommend' colspan='2'>
+ <p class='RecommendationTitle'>Requirement 1-1:</p>
+ </th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr style='background:#C9C9C9;'>
+ <td style='vertical-align:top;' class='recommend' colspan='2'>
+ <p id='_2e2c247b-ce4c-48c5-96dd-f3e090a5b4a7'>Description text</p>
+ </td>
+ </tr>
+ </tbody>
+ </table>
+ </div>
+ <div id='_second_sample'>
+ <h2>
+ 1.2.
+ <span style='mso-tab-count:1'>  </span>
+ Second sample
+ </h2>
+ <table id='_9846c486-14e5-4b1c-bb2f-55cc254dd309' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
+ <thead>
+ <tr style='background:#A5A5A5;'>
+ <th style='vertical-align:top;' class='recommend' colspan='2'>
+ <p class='RecommendationTitle'>Requirement 2:</p>
+ </th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td style='vertical-align:top;' class='recommend' colspan='2'>
+ <p>requirement label</p>
+ </td>
+ </tr>
+ </tbody>
+ </table>
+ <table id='_62de974c-7128-44d6-ba86-99f818f1d467' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
+ <thead>
+ <tr style='background:#A5A5A5;'>
+ <th style='vertical-align:top;' class='recommend' colspan='2'>
+ <p class='RecommendationTitle'>Requirement 2-1:</p>
+ </th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr style='background:#C9C9C9;'>
+ <td style='vertical-align:top;' class='recommend' colspan='2'>
+ <p id='_30b90b08-bd71-4497-bbcc-8c61fbb9f772'>Description text</p>
+ </td>
+ </tr>
+ </tbody>
+ </table>
+ <table id='_fede5681-71f6-47bb-bc65-7bd0b11acd01' class='recommend' style='border-collapse:collapse;border-spacing:0;'>
+ <thead>
+ <tr style='background:#A5A5A5;'>
+ <th style='vertical-align:top;' class='recommend' colspan='2'>
+ <p class='RecommendationTitle'>Requirement 2-2:</p>
+ </th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td style='vertical-align:top;' class='recommend' colspan='2'>
+ <p id='_8daa3d74-90fd-4a57-9169-de457a68cfda'>Description text</p>
+ </td>
+ </tr>
+ </tbody>
+ </table>
+ </div>
+ </body>
+</html>
OUTPUT
- end
+ end
+
end