2023-06-05 11:27:12 -07:00
|
|
|
import os
|
|
|
|
import pathlib
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
2023-05-18 11:40:12 -04:00
|
|
|
from unstructured.partition.xml import partition_xml
|
|
|
|
|
2023-06-05 11:27:12 -07:00
|
|
|
DIRECTORY = pathlib.Path(__file__).parent.resolve()
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_filename(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
elements = partition_xml(filename=file_path, xml_keep_tags=False)
|
|
|
|
|
|
|
|
assert elements[0].text == "United States"
|
|
|
|
assert elements[0].metadata.filename == filename
|
2023-05-18 11:40:12 -04:00
|
|
|
|
2023-06-05 11:27:12 -07:00
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_file(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
with open(file_path) as f:
|
|
|
|
elements = partition_xml(file=f, xml_keep_tags=False, metadata_filename=file_path)
|
2023-05-18 11:40:12 -04:00
|
|
|
|
|
|
|
assert elements[0].text == "United States"
|
2023-06-05 11:27:12 -07:00
|
|
|
assert elements[0].metadata.filename == filename
|
2023-05-18 11:40:12 -04:00
|
|
|
|
|
|
|
|
2023-06-05 11:27:12 -07:00
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_file_rb(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
with open(file_path, "rb") as f:
|
|
|
|
elements = partition_xml(file=f, xml_keep_tags=False, metadata_filename=file_path)
|
2023-05-18 11:40:12 -04:00
|
|
|
|
|
|
|
assert elements[0].text == "United States"
|
2023-06-05 11:27:12 -07:00
|
|
|
assert elements[0].metadata.filename == filename
|
2023-05-18 11:40:12 -04:00
|
|
|
|
|
|
|
|
2023-06-05 11:27:12 -07:00
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_filename_with_tags_default_encoding(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
elements = partition_xml(filename=file_path, xml_keep_tags=True)
|
2023-05-18 11:40:12 -04:00
|
|
|
|
|
|
|
assert elements[5].text == "<name>United States</name>"
|
2023-06-05 11:27:12 -07:00
|
|
|
assert elements[5].metadata.filename == filename
|
|
|
|
|
2023-05-18 11:40:12 -04:00
|
|
|
|
2023-06-05 11:27:12 -07:00
|
|
|
@pytest.mark.parametrize(
|
|
|
|
("filename", "encoding", "error"),
|
|
|
|
[("factbook-utf-16.xml", "utf-8", UnicodeDecodeError)],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_filename_with_tags_raises_encoding_error(filename, encoding, error):
|
|
|
|
with pytest.raises(error):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
partition_xml(filename=file_path, xml_keep_tags=True, encoding=encoding)
|
2023-05-18 11:40:12 -04:00
|
|
|
|
2023-06-05 11:27:12 -07:00
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_file_with_tags_default_encoding(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
with open(file_path) as f:
|
|
|
|
elements = partition_xml(file=f, xml_keep_tags=True, metadata_filename=file_path)
|
2023-05-18 11:40:12 -04:00
|
|
|
|
|
|
|
assert elements[5].text == "<name>United States</name>"
|
2023-06-05 11:27:12 -07:00
|
|
|
assert elements[5].metadata.filename == filename
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
"filename",
|
|
|
|
["factbook.xml", "factbook-utf-16.xml"],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_file_rb_with_tags_default_encoding(filename):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
with open(file_path, "rb") as f:
|
|
|
|
elements = partition_xml(file=f, xml_keep_tags=True, metadata_filename=file_path)
|
|
|
|
|
|
|
|
assert elements[5].text == "<name>United States</name>"
|
|
|
|
assert elements[5].metadata.filename == filename
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
("filename", "encoding", "error"),
|
|
|
|
[("factbook-utf-16.xml", "utf-8", UnicodeDecodeError)],
|
|
|
|
)
|
|
|
|
def test_partition_xml_from_file_rb_with_tags_raises_encoding_error(filename, encoding, error):
|
|
|
|
file_path = os.path.join(DIRECTORY, "..", "..", "example-docs", filename)
|
|
|
|
with pytest.raises(error), open(file_path, "rb") as f:
|
|
|
|
partition_xml(
|
|
|
|
file=f,
|
|
|
|
xml_keep_tags=True,
|
|
|
|
metadata_filename=file_path,
|
|
|
|
encoding=encoding,
|
|
|
|
)
|