# -*- coding: utf-8 -*-
#
# This file is part of Librarian, licensed under GNU Affero GPLv3 or later.
-# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
+# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
#
-from librarian import text, NoDublinCore
+from __future__ import unicode_literals
+
+from librarian import NoDublinCore
+from librarian.parser import WLDocument as LegacyWLDocument
+from librarian.document import WLDocument
from nose.tools import *
-from utils import get_fixture, remove_output_file
+from .utils import get_fixture
+
+def test_transform_legacy():
+ expected_output_file_path = get_fixture('text', 'asnyk_miedzy_nami_expected.txt')
-def teardown_transform():
- remove_output_file('text', 'asnyk_miedzy_nami.txt')
+ text = LegacyWLDocument.from_file(
+ get_fixture('text', 'miedzy-nami-nic-nie-bylo.xml')
+ ).as_text().get_bytes()
+
+ assert_equal(text, open(expected_output_file_path, 'rb').read())
-@with_setup(None, teardown_transform)
def test_transform():
- output_file_path = get_fixture('text', 'asnyk_miedzy_nami.txt')
expected_output_file_path = get_fixture('text', 'asnyk_miedzy_nami_expected.txt')
+
+ text = WLDocument(
+ filename=get_fixture('text', 'miedzy-nami-nic-nie-bylo.xml')
+ ).build('txt').get_bytes()
+
+ assert_equal(text, open(expected_output_file_path, 'rb').read())
+
- text.transform(
- get_fixture('text', 'asnyk_miedzy_nami.xml'),
- output_file_path,
- )
-
- assert_equal(file(output_file_path).read(), file(expected_output_file_path).read())
+def test_transform_raw():
+ expected_output_file_path = get_fixture('text', 'asnyk_miedzy_nami_expected_raw.txt')
+
+ text = LegacyWLDocument.from_file(
+ get_fixture('text', 'miedzy-nami-nic-nie-bylo.xml')
+ ).as_text(flags=['raw-text']).get_bytes()
+
+ assert_equal(text, open(expected_output_file_path, 'rb').read())
-@with_setup(None, teardown_transform)
@raises(NoDublinCore)
def test_no_dublincore():
- text.transform(
- get_fixture('text', 'asnyk_miedzy_nami_nodc.xml'),
- get_fixture('text', 'asnyk_miedzy_nami_nodc.txt'),
- )
+ LegacyWLDocument.from_file(
+ get_fixture('text', 'asnyk_miedzy_nami_nodc.xml')
+ ).as_text()
-@with_setup(None, teardown_transform)
def test_passing_parse_dublincore_to_transform():
- """Passing parse_dublincore=False to transform omits DublinCore parsing."""
- text.transform(
- get_fixture('text', 'asnyk_miedzy_nami_nodc.xml'),
- get_fixture('text', 'asnyk_miedzy_nami.txt'),
- parse_dublincore=False,
- )
-
\ No newline at end of file
+ """Passing parse_dublincore=False to the constructor omits DublinCore parsing."""
+ LegacyWLDocument.from_file(
+ get_fixture('text', 'asnyk_miedzy_nami_nodc.xml'),
+ parse_dublincore=False,
+ ).as_text()