1 # -*- coding: utf-8 -*-
3 # This file is part of Librarian, licensed under GNU Affero GPLv3 or later.
4 # Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
6 from librarian import dcparser
8 from nose.tools import *
9 from os.path import splitext
10 from tests.utils import get_all_fixtures
12 from datetime import date
15 def check_dcparser(xml_file, result_file):
16 xml = file(xml_file).read()
17 result = codecs.open(result_file, encoding='utf-8').read()
18 info = dcparser.BookInfo.from_string(xml).to_dict()
19 should_be = eval(result)
21 assert_equals(info[key], should_be[key])
25 for fixture in get_all_fixtures('dcparser', '*.xml'):
26 base_name = splitext(fixture)[0]
27 yield check_dcparser, fixture, base_name + '.out'
30 def check_serialize(xml_file):
31 xml = file(xml_file).read()
32 info = dcparser.BookInfo.from_string(xml)
35 serialized = etree.tostring(info.to_etree(), encoding=unicode).encode('utf-8')
37 info_bis = dcparser.BookInfo.from_string(serialized)
39 # check if they are the same
40 for key in vars(info):
41 assert_equals(getattr(info, key), getattr(info_bis, key))
42 for key in vars(info_bis):
43 assert_equals(getattr(info, key), getattr(info_bis, key))
47 for fixture in get_all_fixtures('dcparser', '*.xml'):
48 yield check_serialize, fixture
52 assert_equals(dcparser.as_date(u"2010-10-03"), date(2010, 10, 03))
53 assert_equals(dcparser.as_date(u"2011"), date(2011, 1, 1))
54 assert_equals(dcparser.as_date(u"2 poł. XIX w."), date(1950, 1, 1))
55 assert_equals(dcparser.as_date(u"XVII w., l. 20"), date(1720, 1, 1))
56 assert_equals(dcparser.as_date(u"po 1460"), date(1460, 1, 1))
57 assert_equals(dcparser.as_date(u"ok. 1813-1814"), date(1813, 1, 1))
58 assert_equals(dcparser.as_date(u"ok.1876-ok.1886"), date(1876, 1, 1))
59 assert_equals(dcparser.as_date(u"1893/1894"), date(1893, 1, 1))