1
0
Fork 0
mirror of https://github.com/mozilla/pdf.js.git synced 2025-04-24 17:18:07 +02:00
pdf.js/test/font
Tim van der Meij cdce9c2bee
Update the page title/favicon of the test runner HTML files
This commit makes sure that the font tests are no longer reported as
being unit tests and that the PDF.js logo is shown in the browser tab to
make PDF.js-specific resources/tabs more easily identifyable during e.g.
development.
2024-12-22 14:08:56 +01:00
..
font_core_spec.js Replace done callbacks in the font-tests with async/await instead 2021-04-19 13:26:39 +02:00
font_fpgm_spec.js Update ttx from version 2.5 to version 3.19.0 2022-07-10 21:18:36 +02:00
font_os2_spec.js Update ttx from version 2.5 to version 3.19.0 2022-07-10 21:18:36 +02:00
font_post_spec.js Add non-PRODUCTION/TESTING overflow asserts to various string helper-functions (issue 6759) 2021-06-27 16:06:30 +02:00
font_test.html Update the page title/favicon of the test runner HTML files 2024-12-22 14:08:56 +01:00
fontutils.js Simplify the decodeFontData/encodeFontData font-test helper functions 2022-02-25 11:40:03 +01:00
jasmine-boot.js Move the reporter file to the test root folder 2024-12-22 14:08:56 +01:00
README.md Use Python 3.13 in the GitHub workflows 2024-11-12 20:59:01 +01:00
ttxdriver.mjs Convert the TTX driver code to promises 2024-04-05 13:34:54 +02:00

Font tests

The font tests check if PDF.js can read font data correctly. For validation the ttx tool (from the Python fonttools library) is used that can convert font data to an XML format that we can easily use for assertions in the tests. In the font tests we let PDF.js read font data and pass the PDF.js-interpreted font data through ttx to check its correctness. The font tests are successful if PDF.js can successfully read the font data and ttx can successfully read the PDF.js-interpreted font data back, proving that PDF.js does not apply any transformations that break the font data.

Running the font tests

The font tests are run on GitHub Actions using the workflow defined in .github/workflows/font_tests.yml, but it is also possible to run the font tests locally. The current stable versions of the following dependencies are required to be installed on the system:

The recommended way of installing fonttools is using pip in a virtual environment because it avoids having to do a system-wide installation and therefore improves isolation, but any other way of installing fonttools that makes ttx available in the PATH environment variable also works.

Using the virtual environment approach the font tests can be run locally by creating and sourcing a virtual environment with fonttools installed in it before running the font tests:

python3 -m venv venv
source venv/bin/activate
pip install fonttools
npx gulp fonttest