blob: 013628860db50959bac65c0cf486cb45db80523c [file] [log] [blame]
Garret Rieger474afaa2018-03-14 19:15:33 -07001#!/usr/bin/env python
2
Ebrahim Byagowicab2c2c2018-03-29 12:48:47 +04303from __future__ import print_function, division, absolute_import
4
Garret Rieger474afaa2018-03-14 19:15:33 -07005import sys, os, subprocess
6
7srcdir = os.environ.get ("srcdir", ".")
8EXEEXT = os.environ.get ("EXEEXT", "")
9top_builddir = os.environ.get ("top_builddir", ".")
Garret Rieger584693e2018-03-15 18:27:01 -070010hb_subset_fuzzer = os.path.join (top_builddir, "hb-subset-fuzzer" + EXEEXT)
Garret Riegerc02b40e2018-04-17 08:21:22 -060011hb_subset_get_codepoints_fuzzer = os.path.join (top_builddir, "hb-subset-get-codepoints-fuzzer" + EXEEXT)
Garret Rieger474afaa2018-03-14 19:15:33 -070012
13if not os.path.exists (hb_subset_fuzzer):
Garret Riegerc02b40e2018-04-17 08:21:22 -060014 if len (sys.argv) < 2 or not os.path.exists (sys.argv[1]):
Garret Rieger474afaa2018-03-14 19:15:33 -070015 print ("""Failed to find hb-subset-fuzzer binary automatically,
16please provide it as the first argument to the tool""")
17 sys.exit (1)
18
19 hb_subset_fuzzer = sys.argv[1]
20
Garret Riegerc02b40e2018-04-17 08:21:22 -060021if not os.path.exists (hb_subset_get_codepoints_fuzzer):
22 if len (sys.argv) < 3 or not os.path.exists (sys.argv[2]):
23 print ("""Failed to find hb-subset-get-codepoints-fuzzer binary automatically,
24please provide it as the second argument to the tool""")
25 sys.exit (1)
26
27 hb_subset_get_codepoints_fuzzer = sys.argv[2]
28
Garret Rieger474afaa2018-03-14 19:15:33 -070029print ('hb_subset_fuzzer:', hb_subset_fuzzer)
30fails = 0
31
32parent_path = os.path.join (srcdir, "..", "subset", "data", "fonts")
Garret Rieger6f9a5842018-03-15 15:41:08 -070033print ("running subset fuzzer against fonts in %s" % parent_path)
Garret Rieger474afaa2018-03-14 19:15:33 -070034for file in os.listdir (parent_path):
Garret Rieger6f9a5842018-03-15 15:41:08 -070035 path = os.path.join(parent_path, file)
Garret Riegerc02b40e2018-04-17 08:21:22 -060036
Garret Rieger6f9a5842018-03-15 15:41:08 -070037 print ("running subset fuzzer against %s" % path)
38 p = subprocess.Popen ([hb_subset_fuzzer, path])
Garret Rieger474afaa2018-03-14 19:15:33 -070039
40 if p.wait () != 0:
Garret Rieger6f9a5842018-03-15 15:41:08 -070041 print ("failed for %s" % path)
Garret Rieger474afaa2018-03-14 19:15:33 -070042 fails = fails + 1
43
Garret Riegerc02b40e2018-04-17 08:21:22 -060044 print ("running subset get codepoints fuzzer against %s" % path)
45 p = subprocess.Popen ([hb_subset_get_codepoints_fuzzer, path])
46
47 if p.wait () != 0:
48 print ("failed for %s" % path)
49 fails = fails + 1
50
Garret Rieger474afaa2018-03-14 19:15:33 -070051if fails:
Garret Rieger6f9a5842018-03-15 15:41:08 -070052 print ("%i subset fuzzer related tests failed." % fails)
Garret Rieger474afaa2018-03-14 19:15:33 -070053 sys.exit (1)