1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
|
# Copyright (c) 2021, Manfred Moitzi
# License: MIT License
from typing import Iterable, cast
from pathlib import Path
import pytest
import ezdxf
from ezdxf import recover
from ezdxf.entities import MText
DATA = Path(__file__).parent / "data"
TEXT_FRAME = "mtext_text_frame.dxf"
def load_mtext_entities(name: str):
doc = ezdxf.readfile(DATA / name)
return doc
def recover_mtext_entities(name: str):
doc, auditor = recover.readfile(DATA / name)
return doc
@pytest.fixture(scope="module", params=["load", "recover"])
def doc(request):
if request.param == "load":
return load_mtext_entities(TEXT_FRAME)
elif request.param == "recover":
return recover_mtext_entities(TEXT_FRAME)
def test_remove_mtext_text_frame_at_loading_stage(doc):
msp = doc.modelspace()
assert (
len(msp.query("LWPOLYLINE")) == 0
), "text frame entities should be removed"
mtext = msp.query("MTEXT").first
assert bool(mtext.dxf.bg_fill & 16) is True
def test_remove_column_text_frames_at_loading_stage():
doc = ezdxf.readfile(DATA / "mtext_framed_columns.dxf")
msp = doc.modelspace()
assert (
len(msp.query("LWPOLYLINE")) == 0
), "text frame entities should be removed"
def test_do_not_export_mtext_text_borders(tmp_path):
doc1 = ezdxf.readfile(DATA / TEXT_FRAME)
doc1.saveas(tmp_path / TEXT_FRAME)
doc2 = ezdxf.readfile(tmp_path / TEXT_FRAME)
msp = doc2.modelspace()
assert (
len(msp.query("LWPOLYLINE")) == 0
), "text frame entities should be removed"
mtext = msp.query("MTEXT").first
assert mtext.xdata is None, "XDATA for MTEXT_TEXT_BORDERS should be removed"
assert bool(mtext.dxf.bg_fill & 16) is True
if __name__ == "__main__":
pytest.main([__file__])
|