• Home
Name Date Size #Lines LOC

..--

data/12-May-2024-3,6283,130

texts/in-house/12-May-2024-14,97414,655

Makefile.amD12-May-2024692 4031

README.mdD12-May-20241.9 KiB4237

hb-diffD12-May-2024219 105

hb-diff-colorizeD12-May-2024254 84

hb-diff-filter-failuresD12-May-2024167 62

hb-diff-statD12-May-2024109 62

hb-unicode-decodeD12-May-2024131 62

hb-unicode-encodeD12-May-2024135 62

hb-unicode-prettynameD12-May-2024176 73

hb_test_tools.pyD12-May-202411.6 KiB492397

meson.buildD12-May-20241.4 KiB5242

record-test.shD12-May-20243.3 KiB127112

run-tests.pyD12-May-20243.7 KiB143114

README.md

1Adding tests
2============
3
4You can test shaping of a unicode sequence against a font like this:
5```sh
6$ ./hb-unicode-encode 41 42 43 627 | ../../util/hb-shape font.ttf
7```
8assuming an in-tree build.  The 41 42 43 627 here is a sequence of
9Unicode codepoints: U+0041,0042,0043,0627.  When you are happy with
10the shape results, you can use the `record-test.sh` script to add
11this to the test suite.  `record-test.sh` requires `pyftsubset` to
12be installed.  You can get `pyftsubset` by installing
13FontTools from <https://github.com/behdad/fonttools>.
14
15To use `record-test.sh`, just put it right before the `hb-shape` invocation:
16```sh
17$ ./hb-unicode-encode 41 42 43 627 | ./record-test.sh ../../util/hb-shape font.ttf
18```
19what this does is:
20  * Subset the font for the sequence of Unicode characters requested,
21  * Compare the `hb-shape` output of the original font versus the subset
22    font for the input sequence,
23  * If the outputs differ, perhaps it is because the font does not have
24    glyph names; it then compares the output of `hb-view` for both fonts.
25  * If the outputs differ, recording fails.  Otherwise, it will move the
26    subset font file into `data/in-house/fonts` and name it after its
27    hash, and print out the test case input, which you can then redirect
28    to an existing or new test file in `data/in-house/tests` using `-o`,
29    e.g.:
30```sh
31$ ./hb-unicode-encode 41 42 43 627 | ./record-test.sh -o data/in-house/tests/test-name.test ../../util/hb-shape font.ttf
32```
33
34If you created a new test file, add it to `data/in-house/Makefile.sources`
35so it is run.  Check that `make check` does indeed run it, and that the
36test passes.  When everything looks good, `git add` the new font as well
37as the new test file if you created any.  You can see what new files are
38there by running `git status data/in-house`.  And commit!
39
40*Note!*  Please only add tests using Open Source fonts, preferably under
41OFL or similar license.
42