1
0
Fork 0
inkscape/share/extensions/tests/test_media_zip.py
Daniel Baumann 02d935e272
Adding upstream version 1.4.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
2025-06-22 23:40:13 +02:00

56 lines
1.9 KiB
Python

# coding=utf-8
import io
import zipfile
import re
from media_zip import CompressedMedia
from inkex.tester import ComparisonMixin, TestCase
from inkex.tester.filters import CompareSize
class CmoTestEmbed(TestCase):
def test_complex(self):
params = (self.data_file("svg", "embed.svg"), "--font_list=True")
cmo = CompressedMedia()
out = io.BytesIO()
cmo.run(params, output=out)
result = io.BytesIO(out.getvalue())
with zipfile.ZipFile(result, mode="r") as f:
files = f.filelist
files = {i.filename for i in files}
self.assertEqual(
files,
{
"images/linecap.png", # this file is referenced twice
# this file has the same filename, but
# different source path, so a 1 is appended
"images/linecap1.png",
"images/markers.svg",
"embed.svg",
"fontlist.txt",
},
)
# Assert that the image tags have updated links
svg = f.read("embed.svg").decode("utf8")
matches = re.finditer(r'xlink:href="(.*)"', svg)
self.assertEqual(len(list(matches)), 5)
for match in matches:
if match.groups(1).startswith("data"):
continue
self.assertTrue(match.groups(1).startswith("images/"))
# Assert that the font list is correct
fontlist = f.read("fontlist.txt").decode("utf8")
fontlist = fontlist.splitlines()[1:]
self.assertEqual(
[i.replace('"', "'") for i in fontlist], # normalize quote delimiters
[
"'Courier New' normal",
"'Times New Roman'",
"Arial normal",
"Verdana normal",
],
)