Better handling of multipart DAISY.
[librarian.git] / tests / test_html.py
index d77d8fe..36651fa 100644 (file)
@@ -5,39 +5,53 @@
 #
 from __future__ import unicode_literals
 
 #
 from __future__ import unicode_literals
 
+import io
+from unittest import TestCase
 from librarian import NoDublinCore
 from librarian import NoDublinCore
-from librarian.parser import WLDocument
+from librarian.document import WLDocument
+from librarian.parser import WLDocument as LegacyWLDocument
 from nose.tools import *
 from .utils import get_fixture
 
 
 from nose.tools import *
 from .utils import get_fixture
 
 
-def test_transform():
-    expected_output_file_path = get_fixture('text', 'asnyk_miedzy_nami_expected.html')
+class TransformTest(TestCase):
+    maxDiff = None
 
 
-    html = WLDocument.from_file(
+    def test_transform_legacy(self):
+        expected_output_file_path = get_fixture('text', 'asnyk_miedzy_nami_expected.legacy.html')
+
+        html = LegacyWLDocument.from_file(
             get_fixture('text', 'miedzy-nami-nic-nie-bylo.xml')
             get_fixture('text', 'miedzy-nami-nic-nie-bylo.xml')
-        ).as_html().get_bytes()
+        ).as_html().get_bytes().decode('utf-8')
+
+        self.assertEqual(html, io.open(expected_output_file_path).read())
+
+    def test_transform(self):
+        expected_output_file_path = get_fixture('text', 'asnyk_miedzy_nami_expected.html')
+        html = WLDocument(
+            filename=get_fixture('text', 'miedzy-nami-nic-nie-bylo.xml')
+        ).build('html').get_bytes().decode('utf-8')
 
 
-    assert_equal(html, open(expected_output_file_path, 'rb').read())
+        self.assertEqual(html, io.open(expected_output_file_path).read())
 
 
 @raises(NoDublinCore)
 def test_no_dublincore():
 
 
 @raises(NoDublinCore)
 def test_no_dublincore():
-    WLDocument.from_file(
+    LegacyWLDocument.from_file(
             get_fixture('text', 'asnyk_miedzy_nami_nodc.xml')
         ).as_html()
 
 
 def test_passing_parse_dublincore_to_transform():
     """Passing parse_dublincore=False to transform omits DublinCore parsing."""
             get_fixture('text', 'asnyk_miedzy_nami_nodc.xml')
         ).as_html()
 
 
 def test_passing_parse_dublincore_to_transform():
     """Passing parse_dublincore=False to transform omits DublinCore parsing."""
-    WLDocument.from_file(
+    LegacyWLDocument.from_file(
             get_fixture('text', 'asnyk_miedzy_nami_nodc.xml'),
             parse_dublincore=False,
         ).as_html()
 
 
 def test_empty():
             get_fixture('text', 'asnyk_miedzy_nami_nodc.xml'),
             parse_dublincore=False,
         ).as_html()
 
 
 def test_empty():
-    assert not WLDocument.from_bytes(
+    assert not LegacyWLDocument.from_bytes(
             b'<utwor />',
             parse_dublincore=False,
         ).as_html()
             b'<utwor />',
             parse_dublincore=False,
         ).as_html()