Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F76320890
bibedit_unit_tests.py
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Wed, Aug 7, 08:51
Size
5 KB
Mime Type
text/x-python
Expires
Fri, Aug 9, 08:51 (1 d, 21 h)
Engine
blob
Format
Raw Data
Handle
19649380
Attached To
R3600 invenio-infoscience
bibedit_unit_tests.py
View Options
# -*- coding: utf-8 -*-
##
## This file is part of Invenio.
## Copyright (C) 2012, 2013 CERN.
##
## Invenio is free software; you can redistribute it and/or
## modify it under the terms of the GNU General Public License as
## published by the Free Software Foundation; either version 2 of the
## License, or (at your option) any later version.
##
## Invenio is distributed in the hope that it will be useful, but
## WITHOUT ANY WARRANTY; without even the implied warranty of
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
## General Public License for more details.
##
## You should have received a copy of the GNU General Public License
## along with Invenio; if not, write to the Free Software Foundation, Inc.,
## 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
"""Unit tests for BibEdit functions"""
import
unittest
import
re
from
invenio.testutils
import
make_test_suite
,
run_test_suite
from
invenio.bibedit_utils
import
get_xml_from_textmarc
from
invenio.bibedit_engine
import
perform_doi_search
class
TextmarcToXMLTests
(
unittest
.
TestCase
):
""" Test utility functions to convert textmarc to XML """
def
test_get_xml_from_textmarc_success
(
self
):
textmarc
=
"""100__ $$aDoe, J.$$uCERN
245__ $$aPion production by 24 GeV/c protons in hydrogen
260__ $$c1961
300__ $$a15"""
output
=
get_xml_from_textmarc
(
1
,
textmarc
)
self
.
assertEqual
(
output
[
'resultMsg'
],
'textmarc_parsing_success'
)
xml_expected_output
=
"""<record>
<controlfield tag="001">1</controlfield>
<datafield tag="100" ind1=" " ind2=" ">
<subfield code="a">Doe, J.</subfield>
<subfield code="u">CERN</subfield>
</datafield>
<datafield tag="245" ind1=" " ind2=" ">
<subfield code="a">Pion production by 24 GeV/c protons in hydrogen</subfield>
</datafield>
<datafield tag="260" ind1=" " ind2=" ">
<subfield code="c">1961</subfield>
</datafield>
<datafield tag="300" ind1=" " ind2=" ">
<subfield code="a">15</subfield>
</datafield>
</record>
"""
self
.
assertEqual
(
re
.
sub
(
"\s+"
,
" "
,
output
[
'resultXML'
]
.
strip
()),
re
.
sub
(
"\s+"
,
" "
,
xml_expected_output
.
strip
()))
def
test_get_xml_from_textmarc_wrong_field
(
self
):
textmarc
=
"""1sasd00__ $$aDoe, J.$$uCERN
245__ $$aPion production by 24 GeV/c protons in hydrogen
260__ $$c1961
300__ $$a15"""
output
=
get_xml_from_textmarc
(
1
,
textmarc
)
self
.
assertEqual
(
output
[
'resultMsg'
],
'textmarc_parsing_error'
)
expected_error
=
[
1
,
"1sasd00__ $$aDoe, J.$$uCERN"
]
self
.
assertEqual
(
output
[
'parse_error'
][:
-
1
],
expected_error
)
def
test_get_xml_from_textmarc_wrong_content
(
self
):
textmarc
=
"""100__ $$a
245__ $$aPion production by 24 GeV/c protons in hydrogen
260__ $$c1961
300__ $$a15"""
output
=
get_xml_from_textmarc
(
1
,
textmarc
)
# We expect success now, ignoring empty field, see ticket:1269.
# <http://invenio-software.org/ticket/1269>
self
.
assertEqual
(
output
[
'resultMsg'
],
'textmarc_parsing_success'
)
self
.
assertEqual
(
output
[
'resultXML'
],
"""<record>
<controlfield tag="001">1</controlfield>
<datafield tag="245" ind1=" " ind2=" ">
<subfield code="a">Pion production by 24 GeV/c protons in hydrogen</subfield>
</datafield>
<datafield tag="260" ind1=" " ind2=" ">
<subfield code="c">1961</subfield>
</datafield>
<datafield tag="300" ind1=" " ind2=" ">
<subfield code="a">15</subfield>
</datafield>
</record>
"""
)
def
test_accept_fft_tags_in_textmarc
(
self
):
textmarc
=
"""100__ $$aDoe, J.$$uCERN
FFT__ $$ahttp://scd-theses.u-strasbg.fr/1818/01/RICAUD_Helene_2008.pdf$$dFulltext"""
output
=
get_xml_from_textmarc
(
1
,
textmarc
)
xml_expected_output
=
"""<record>
<controlfield tag="001">1</controlfield>
<datafield tag="100" ind1=" " ind2=" ">
<subfield code="a">Doe, J.</subfield>
<subfield code="u">CERN</subfield>
</datafield>
<datafield tag="FFT" ind1=" " ind2=" ">
<subfield code="a">http://scd-theses.u-strasbg.fr/1818/01/RICAUD_Helene_2008.pdf</subfield>
<subfield code="d">Fulltext</subfield>
</datafield>
</record>"""
self
.
assertEqual
(
re
.
sub
(
"\s+"
,
" "
,
output
[
'resultXML'
]
.
strip
()),
re
.
sub
(
"\s+"
,
" "
,
xml_expected_output
.
strip
()))
class
TestPerformDoiSearch
(
unittest
.
TestCase
):
"""Test the perform_doi_search function, which resolves the doi using
dx.doi.org page and returns the url of the resource
"""
def
test_normal
(
self
):
"""Checks if some standard doi is working"""
doi
=
"10.1007/BF02724522"
wrong_output
=
{}
self
.
assertNotEqual
(
perform_doi_search
(
doi
),
wrong_output
)
def
test_no_headers
(
self
):
"""Checks if the doi that requires 'User-Agent' header is working"""
doi
=
"10.1016/0550-3213(89)90423-9"
wrong_output
=
{}
self
.
assertNotEqual
(
perform_doi_search
(
doi
),
wrong_output
)
TEST_SUITE
=
make_test_suite
(
TextmarcToXMLTests
,
TestPerformDoiSearch
)
if
__name__
==
"__main__"
:
run_test_suite
(
TEST_SUITE
)
Event Timeline
Log In to Comment