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
|
# 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(
fontlist,
[
"'Courier New' normal",
"'Times New Roman'",
"Arial normal",
"Verdana normal",
],
)
|