Running as unit: rb-build-amd64_7-40090.service ==================================================================================== Sun Nov 24 19:22:27 UTC 2024 - running /srv/jenkins/bin/reproducible_build.sh (for job reproducible_builder_amd64_7) on jenkins, called using "ionos11-amd64 ionos15-amd64" as arguments. Sun Nov 24 19:22:27 UTC 2024 - actually running "reproducible_build.sh" (md5sum 68e686e434c9ab7bc3ec047d8b309cbc) as "/tmp/jenkins-script-e2riV8WR" $ git clone https://salsa.debian.org/qa/jenkins.debian.net.git ; more CONTRIBUTING Sun Nov 24 19:22:28 UTC 2024 - checking /var/lib/jenkins/offline_nodes if ionos11-amd64.debian.net is marked as down. Sun Nov 24 19:22:28 UTC 2024 - checking via ssh if ionos11-amd64.debian.net is up. removed '/tmp/read-only-fs-test-CpZ8mM' Sun Nov 24 19:22:28 UTC 2024 - checking /var/lib/jenkins/offline_nodes if ionos15-amd64.debian.net is marked as down. Sun Nov 24 19:22:28 UTC 2024 - checking via ssh if ionos15-amd64.debian.net is up. removed '/tmp/read-only-fs-test-Hr2fyp' ok, let's check if ufo2ft is building anywhere yet… ok, ufo2ft is not building anywhere… UPDATE 1 ============================================================================= Initialising reproducibly build of ufo2ft in unstable on amd64 on jenkins now. 1st build will be done on ionos11-amd64.debian.net. 2nd build will be done on ionos15-amd64.debian.net. ============================================================================= Sun Nov 24 19:22:42 UTC 2024 I: starting to build ufo2ft/unstable/amd64 on jenkins on '2024-11-24 19:22' Sun Nov 24 19:22:42 UTC 2024 I: The jenkins build log is/was available at https://jenkins.debian.net/userContent/reproducible/debian/build_service/amd64_7/40090/console.log 1732476162 amd64 unstable ufo2ft Sun Nov 24 19:22:42 UTC 2024 I: Downloading source for unstable/ufo2ft=3.3.1-2 --2024-11-24 19:22:42-- http://deb.debian.org/debian/pool/main/u/ufo2ft/ufo2ft_3.3.1-2.dsc Connecting to 46.16.76.132:3128... connected. Proxy request sent, awaiting response... 200 OK Length: 2508 (2.4K) [text/prs.lines.tag] Saving to: ‘ufo2ft_3.3.1-2.dsc’ 0K .. 100% 347M=0s 2024-11-24 19:22:42 (347 MB/s) - ‘ufo2ft_3.3.1-2.dsc’ saved [2508/2508] --2024-11-24 19:22:42-- http://deb.debian.org/debian/pool/main/u/ufo2ft/ufo2ft_3.3.1-2.dsc Connecting to 46.16.76.132:3128... connected. Proxy request sent, awaiting response... 200 OK Length: 2508 (2.4K) [text/prs.lines.tag] Saving to: ‘ufo2ft_3.3.1-2.dsc’ 0K .. 100% 347M=0s 2024-11-24 19:22:42 (347 MB/s) - ‘ufo2ft_3.3.1-2.dsc’ saved [2508/2508] Sun Nov 24 19:22:42 UTC 2024 I: ufo2ft_3.3.1-2.dsc -----BEGIN PGP SIGNED MESSAGE----- Hash: SHA512 Format: 3.0 (quilt) Source: ufo2ft Binary: python3-ufo2ft Architecture: all Version: 3.3.1-2 Maintainer: Debian Fonts Task Force Uploaders: Jeremy Bicha , Yao Wei (魏銘廷) Homepage: https://github.com/googlei18n/ufo2ft/ Description: Bridge from UFOs to fonttools objects python3-ufo2ft converts fonts from UFO, a common font source format, to fonttools Python objects, which can subsequently saved as OTF or TTF binaries. Standards-Version: 4.7.0 Vcs-Browser: https://salsa.debian.org/fonts-team/ufo2ft Vcs-Git: https://salsa.debian.org/fonts-team/ufo2ft.git Testsuite: autopkgtest-pkg-python Build-Depends: debhelper-compat (= 13), dh-sequence-python3, python3-all, python3-setuptools, python3-setuptools-scm, python3-pytest , python3-fontmath, python3-fonttools (>= 4.50.0), python3-ufolib2 (>= 0.16.0), python3-defcon (>= 0.10.0), python3-syrupy , python3-compreffor (>= 0.5.5), python3-booleanoperations (>= 0.9.0), python3-cffsubr (>= 0.2.9) Package-List: python3-ufo2ft deb python optional arch=all Checksums-Sha1: 5eb0542c68427be9d7874f8e2bb78323d1aecd70 398897 ufo2ft_3.3.1.orig.tar.gz 5a433794ba6decf2637e593982dee978d0da8ca6 6224 ufo2ft_3.3.1-2.debian.tar.xz Checksums-Sha256: 7caf0b8ef9937597180f25e4d3d32f96668c817d81f89d5b7a51329e7cff008d 398897 ufo2ft_3.3.1.orig.tar.gz 1720190ad7bf6acc2f072fd7330a3f317925d95c8b1cfb1d0aa863c1e24c3c3d 6224 ufo2ft_3.3.1-2.debian.tar.xz Files: 9e0031bef6903405c9ca21c7e20517c7 398897 ufo2ft_3.3.1.orig.tar.gz c1da519ea6a588ee4e9033d539fe8d8c 6224 ufo2ft_3.3.1-2.debian.tar.xz -----BEGIN PGP SIGNATURE----- iQIzBAEBCgAdFiEEfncpR22H1vEdkazLwpPntGGCWs4FAmcY+qwACgkQwpPntGGC Ws7o/Q//RWYbxFpNj+RgwJn2J1P2WIMSyrr0hNTgDNLAmLiZCR6ZMQbU5w99vOyY ZG/qdyLNE1CVhV9G1cDQJhHXMay/fEbMysDO9icyqmhuJxw4EOJyxISQ5jzCcNFM PYW75NLT/trnvvWVn58qRANI2cioybGuAVCGVbBaB7BXq6iIaQ7gQ6Vxpw7xHFRI la5JF01rbWL2HrK3AVPNOYhjInlSkMLhTBSrXhJVOgjEb+NWHyk+KbFrnLhDftPx I+x1Ru+lE6EqsxsxhQro2KGT3oQye/spjb2im8eQiBKcZQHE/ogc1bWF26R0Ikxv 36eXmaBpcOjFlCtvj7IdIMaOsRu0uXyMc/MCGCcSKfGkX9vQfvYnfz+PvLcUdB2Y jr7D4WgaZ1zMxT65BaHx5lyhrQK/NJC4uOz+zdPENy4hKf9XlO8qqlw8wsk/Ifsj 67Px5JElYDCzgY29kigSJdK3TQzf0457uei2GD2yMSMatOiea3tFBjYS6cQYeQez 4GJW/mbp9fBXWmzINwAk3ef/r+nzBeEDb22MCYjVh3qQ6qqHI1hHvgTupKpbsfhO zVXe2WFjamxeAg16XPRboCGNFzwCDNZB3Bq1kXEKJV155rliveaEdXmd9oPgXRRo 29zjoqtN3So2752Xu8epM2cOXYO0h3WmYfDRW7PI5mmJ1TcOR98= =WGYW -----END PGP SIGNATURE----- Sun Nov 24 19:22:42 UTC 2024 I: Checking whether the package is not for us Sun Nov 24 19:22:42 UTC 2024 I: Starting 1st build on remote node ionos11-amd64.debian.net. Sun Nov 24 19:22:42 UTC 2024 I: Preparing to do remote build '1' on ionos11-amd64.debian.net. Sun Nov 24 19:22:42 UTC 2024 - checking /var/lib/jenkins/offline_nodes if ionos11-amd64.debian.net is marked as down. Sun Nov 24 19:22:42 UTC 2024 - checking via ssh if ionos11-amd64.debian.net is up. removed '/tmp/read-only-fs-test-OLGaxO' ==================================================================================== Sun Nov 24 19:22:44 UTC 2024 - running /srv/jenkins/bin/reproducible_build.sh (for job /srv/jenkins/bin/reproducible_build.sh) on ionos11-amd64, called using "1 ufo2ft unstable /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf 3.3.1-2" as arguments. Sun Nov 24 19:22:44 UTC 2024 - actually running "reproducible_build.sh" (md5sum 68e686e434c9ab7bc3ec047d8b309cbc) as "/tmp/jenkins-script-wcYxy7nB" $ git clone https://salsa.debian.org/qa/jenkins.debian.net.git ; more CONTRIBUTING Sun Nov 24 19:22:44 UTC 2024 I: Downloading source for unstable/ufo2ft=3.3.1-2 Reading package lists... NOTICE: 'ufo2ft' packaging is maintained in the 'Git' version control system at: https://salsa.debian.org/fonts-team/ufo2ft.git Please use: git clone https://salsa.debian.org/fonts-team/ufo2ft.git to retrieve the latest (possibly unreleased) updates to the package. Need to get 408 kB of source archives. Get:1 http://deb.debian.org/debian unstable/main ufo2ft 3.3.1-2 (dsc) [2508 B] Get:2 http://deb.debian.org/debian unstable/main ufo2ft 3.3.1-2 (tar) [399 kB] Get:3 http://deb.debian.org/debian unstable/main ufo2ft 3.3.1-2 (diff) [6224 B] Fetched 408 kB in 0s (7139 kB/s) Download complete and in download only mode Reading package lists... NOTICE: 'ufo2ft' packaging is maintained in the 'Git' version control system at: https://salsa.debian.org/fonts-team/ufo2ft.git Please use: git clone https://salsa.debian.org/fonts-team/ufo2ft.git to retrieve the latest (possibly unreleased) updates to the package. Need to get 408 kB of source archives. Get:1 http://deb.debian.org/debian unstable/main ufo2ft 3.3.1-2 (dsc) [2508 B] Get:2 http://deb.debian.org/debian unstable/main ufo2ft 3.3.1-2 (tar) [399 kB] Get:3 http://deb.debian.org/debian unstable/main ufo2ft 3.3.1-2 (diff) [6224 B] Fetched 408 kB in 0s (7139 kB/s) Download complete and in download only mode ============================================================================= Building ufo2ft in unstable on amd64 on ionos11-amd64 now. Date: Sun Nov 24 19:22:45 UTC 2024 Date UTC: Sun Nov 24 19:22:45 UTC 2024 ============================================================================= W: /root/.pbuilderrc does not exist I: Logging to b1/build.log I: pbuilder: network access will be disabled during build I: Current time: Sun Nov 24 07:22:45 -12 2024 I: pbuilder-time-stamp: 1732476165 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/unstable-reproducible-base.tgz] I: copying local configuration W: --override-config is not set; not updating apt.conf Read the manpage for details. I: mounting /proc filesystem I: mounting /sys filesystem I: creating /{dev,run}/shm I: mounting /dev/pts filesystem I: redirecting /dev/ptmx to /dev/pts/ptmx I: policy-rc.d already exists I: Copying source file I: copying [ufo2ft_3.3.1-2.dsc] I: copying [./ufo2ft_3.3.1.orig.tar.gz] I: copying [./ufo2ft_3.3.1-2.debian.tar.xz] I: Extracting source gpgv: Signature made Wed Oct 23 13:31:24 2024 gpgv: using RSA key 7E7729476D87D6F11D91ACCBC293E7B461825ACE gpgv: Can't check signature: No public key dpkg-source: warning: cannot verify inline signature for ./ufo2ft_3.3.1-2.dsc: no acceptable signature found dpkg-source: info: extracting ufo2ft in ufo2ft-3.3.1 dpkg-source: info: unpacking ufo2ft_3.3.1.orig.tar.gz dpkg-source: info: unpacking ufo2ft_3.3.1-2.debian.tar.xz dpkg-source: info: using patch list from debian/patches/series dpkg-source: info: applying disable-pathops-test.patch dpkg-source: info: applying Add-files-to-avoid-clean-target-failure.patch I: using fakeroot in build. I: Installing the build-deps I: user script /srv/workspace/pbuilder/894615/tmp/hooks/D02_print_environment starting I: set BUILDDIR='/build/reproducible-path' BUILDUSERGECOS='first user,first room,first work-phone,first home-phone,first other' BUILDUSERNAME='pbuilder1' BUILD_ARCH='amd64' DEBIAN_FRONTEND='noninteractive' DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=20 ' DISTRIBUTION='unstable' HOME='/root' HOST_ARCH='amd64' IFS=' ' INVOCATION_ID='8b467b916a84408090859ead7c9f7d87' LANG='C' LANGUAGE='en_US:en' LC_ALL='C' MAIL='/var/mail/root' OPTIND='1' PATH='/usr/sbin:/usr/bin:/sbin:/bin:/usr/games' PBCURRENTCOMMANDLINEOPERATION='build' PBUILDER_OPERATION='build' PBUILDER_PKGDATADIR='/usr/share/pbuilder' PBUILDER_PKGLIBDIR='/usr/lib/pbuilder' PBUILDER_SYSCONFDIR='/etc' PPID='894615' PS1='# ' PS2='> ' PS4='+ ' PWD='/' SHELL='/bin/bash' SHLVL='2' SUDO_COMMAND='/usr/bin/timeout -k 18.1h 18h /usr/bin/ionice -c 3 /usr/bin/nice /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/pbuilderrc_0MIM --distribution unstable --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b1 --logfile b1/build.log ufo2ft_3.3.1-2.dsc' SUDO_GID='111' SUDO_UID='106' SUDO_USER='jenkins' TERM='unknown' TZ='/usr/share/zoneinfo/Etc/GMT+12' USER='root' _='/usr/bin/systemd-run' http_proxy='http://46.16.76.132:3128' I: uname -a Linux ionos11-amd64 6.1.0-27-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.115-1 (2024-11-01) x86_64 GNU/Linux I: ls -l /bin lrwxrwxrwx 1 root root 7 Nov 22 14:40 /bin -> usr/bin I: user script /srv/workspace/pbuilder/894615/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy Version: 0.invalid.0 Architecture: amd64 Maintainer: Debian Pbuilder Team Description: Dummy package to satisfy dependencies with aptitude - created by pbuilder This package was created automatically by pbuilder to satisfy the build-dependencies of the package being currently built. Depends: debhelper-compat (= 13), dh-sequence-python3, python3-all, python3-setuptools, python3-setuptools-scm, python3-pytest, python3-fontmath, python3-fonttools (>= 4.50.0), python3-ufolib2 (>= 0.16.0), python3-defcon (>= 0.10.0), python3-syrupy, python3-compreffor (>= 0.5.5), python3-booleanoperations (>= 0.9.0), python3-cffsubr (>= 0.2.9) dpkg-deb: building package 'pbuilder-satisfydepends-dummy' in '/tmp/satisfydepends-aptitude/pbuilder-satisfydepends-dummy.deb'. Selecting previously unselected package pbuilder-satisfydepends-dummy. (Reading database ... 19966 files and directories currently installed.) Preparing to unpack .../pbuilder-satisfydepends-dummy.deb ... Unpacking pbuilder-satisfydepends-dummy (0.invalid.0) ... dpkg: pbuilder-satisfydepends-dummy: dependency problems, but configuring anyway as you requested: pbuilder-satisfydepends-dummy depends on debhelper-compat (= 13); however: Package debhelper-compat is not installed. pbuilder-satisfydepends-dummy depends on dh-sequence-python3; however: Package dh-sequence-python3 is not installed. pbuilder-satisfydepends-dummy depends on python3-all; however: Package python3-all is not installed. pbuilder-satisfydepends-dummy depends on python3-setuptools; however: Package python3-setuptools is not installed. pbuilder-satisfydepends-dummy depends on python3-setuptools-scm; however: Package python3-setuptools-scm is not installed. pbuilder-satisfydepends-dummy depends on python3-pytest; however: Package python3-pytest is not installed. pbuilder-satisfydepends-dummy depends on python3-fontmath; however: Package python3-fontmath is not installed. pbuilder-satisfydepends-dummy depends on python3-fonttools (>= 4.50.0); however: Package python3-fonttools is not installed. pbuilder-satisfydepends-dummy depends on python3-ufolib2 (>= 0.16.0); however: Package python3-ufolib2 is not installed. pbuilder-satisfydepends-dummy depends on python3-defcon (>= 0.10.0); however: Package python3-defcon is not installed. pbuilder-satisfydepends-dummy depends on python3-syrupy; however: Package python3-syrupy is not installed. pbuilder-satisfydepends-dummy depends on python3-compreffor (>= 0.5.5); however: Package python3-compreffor is not installed. pbuilder-satisfydepends-dummy depends on python3-booleanoperations (>= 0.9.0); however: Package python3-booleanoperations is not installed. pbuilder-satisfydepends-dummy depends on python3-cffsubr (>= 0.2.9); however: Package python3-cffsubr is not installed. Setting up pbuilder-satisfydepends-dummy (0.invalid.0) ... Reading package lists... Building dependency tree... Reading state information... Initializing package states... Writing extended state information... Building tag database... pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) The following NEW packages will be installed: afdko-bin{a} autoconf{a} automake{a} autopoint{a} autotools-dev{a} bsdextrautils{a} debhelper{a} dh-autoreconf{a} dh-python{a} dh-strip-nondeterminism{a} dwz{a} file{a} gettext{a} gettext-base{a} groff-base{a} intltool-debian{a} libantlr4-runtime4.9{a} libarchive-zip-perl{a} libblas3{a} libcom-err2{a} libdebhelper-perl{a} libelf1t64{a} libexpat1{a} libfile-stripnondeterminism-perl{a} libgfortran5{a} libgssapi-krb5-2{a} libicu72{a} libjs-jquery{a} libjs-sphinxdoc{a} libjs-underscore{a} libk5crypto3{a} libkeyutils1{a} libkrb5-3{a} libkrb5support0{a} liblapack3{a} liblbfgsb0{a} libmagic-mgc{a} libmagic1t64{a} libnsl2{a} libpipeline1{a} libpython3-stdlib{a} libpython3.12-minimal{a} libpython3.12-stdlib{a} libpython3.13-minimal{a} libpython3.13-stdlib{a} libreadline8t64{a} libtirpc-common{a} libtirpc3t64{a} libtool{a} libuchardet0{a} libxml2{a} libxslt1.1{a} m4{a} man-db{a} media-types{a} netbase{a} po-debconf{a} python3{a} python3-all{a} python3-appdirs{a} python3-attr{a} python3-autocommand{a} python3-booleanoperations{a} python3-brotli{a} python3-cffsubr{a} python3-compreffor{a} python3-decorator{a} python3-defcon{a} python3-fontmath{a} python3-fonttools{a} python3-fs{a} python3-inflect{a} python3-iniconfig{a} python3-jaraco.context{a} python3-jaraco.functools{a} python3-jaraco.text{a} python3-lxml{a} python3-lz4{a} python3-minimal{a} python3-more-itertools{a} python3-mpmath{a} python3-numpy{a} python3-packaging{a} python3-pkg-resources{a} python3-pluggy{a} python3-pyclipper{a} python3-pytest{a} python3-scipy{a} python3-setuptools{a} python3-setuptools-scm{a} python3-six{a} python3-sympy{a} python3-syrupy{a} python3-typeguard{a} python3-typing-extensions{a} python3-tz{a} python3-ufolib2{a} python3-zipp{a} python3.12{a} python3.12-minimal{a} python3.13{a} python3.13-minimal{a} readline-common{a} sensible-utils{a} tzdata{a} unicode-data{a} The following packages are RECOMMENDED but will NOT be installed: ca-certificates curl isympy-common javascript-common krb5-locales libarchive-cpio-perl libltdl-dev libmail-sendmail-perl lynx python3-bs4 python3-cssselect python3-fontpens python3-html5lib python3-pil python3-pooch python3-pygments wget 0 packages upgraded, 106 newly installed, 0 to remove and 0 not upgraded. Need to get 82.8 MB of archives. After unpacking 407 MB will be used. Writing extended state information... Get: 1 http://deb.debian.org/debian unstable/main amd64 libpython3.12-minimal amd64 3.12.7-3 [815 kB] Get: 2 http://deb.debian.org/debian unstable/main amd64 libexpat1 amd64 2.6.4-1 [106 kB] Get: 3 http://deb.debian.org/debian unstable/main amd64 python3.12-minimal amd64 3.12.7-3 [2162 kB] Get: 4 http://deb.debian.org/debian unstable/main amd64 python3-minimal amd64 3.12.7-1 [26.8 kB] Get: 5 http://deb.debian.org/debian unstable/main amd64 media-types all 10.1.0 [26.9 kB] Get: 6 http://deb.debian.org/debian unstable/main amd64 netbase all 6.4 [12.8 kB] Get: 7 http://deb.debian.org/debian unstable/main amd64 tzdata all 2024b-3 [255 kB] Get: 8 http://deb.debian.org/debian unstable/main amd64 libkrb5support0 amd64 1.21.3-3 [32.5 kB] Get: 9 http://deb.debian.org/debian unstable/main amd64 libcom-err2 amd64 1.47.1-1+b1 [23.2 kB] Get: 10 http://deb.debian.org/debian unstable/main amd64 libk5crypto3 amd64 1.21.3-3 [79.9 kB] Get: 11 http://deb.debian.org/debian unstable/main amd64 libkeyutils1 amd64 1.6.3-4 [9092 B] Get: 12 http://deb.debian.org/debian unstable/main amd64 libkrb5-3 amd64 1.21.3-3 [324 kB] Get: 13 http://deb.debian.org/debian unstable/main amd64 libgssapi-krb5-2 amd64 1.21.3-3 [136 kB] Get: 14 http://deb.debian.org/debian unstable/main amd64 libtirpc-common all 1.3.4+ds-1.3 [10.9 kB] Get: 15 http://deb.debian.org/debian unstable/main amd64 libtirpc3t64 amd64 1.3.4+ds-1.3+b1 [83.1 kB] Get: 16 http://deb.debian.org/debian unstable/main amd64 libnsl2 amd64 1.3.0-3+b3 [40.6 kB] Get: 17 http://deb.debian.org/debian unstable/main amd64 readline-common all 8.2-5 [69.3 kB] Get: 18 http://deb.debian.org/debian unstable/main amd64 libreadline8t64 amd64 8.2-5 [169 kB] Get: 19 http://deb.debian.org/debian unstable/main amd64 libpython3.12-stdlib amd64 3.12.7-3 [1966 kB] Get: 20 http://deb.debian.org/debian unstable/main amd64 python3.12 amd64 3.12.7-3 [671 kB] Get: 21 http://deb.debian.org/debian unstable/main amd64 libpython3-stdlib amd64 3.12.7-1 [9712 B] Get: 22 http://deb.debian.org/debian unstable/main amd64 python3 amd64 3.12.7-1 [27.8 kB] Get: 23 http://deb.debian.org/debian unstable/main amd64 libpython3.13-minimal amd64 3.13.0-2 [856 kB] Get: 24 http://deb.debian.org/debian unstable/main amd64 python3.13-minimal amd64 3.13.0-2 [2038 kB] Get: 25 http://deb.debian.org/debian unstable/main amd64 sensible-utils all 0.0.24 [24.8 kB] Get: 26 http://deb.debian.org/debian unstable/main amd64 libmagic-mgc amd64 1:5.45-3+b1 [314 kB] Get: 27 http://deb.debian.org/debian unstable/main amd64 libmagic1t64 amd64 1:5.45-3+b1 [108 kB] Get: 28 http://deb.debian.org/debian unstable/main amd64 file amd64 1:5.45-3+b1 [43.3 kB] Get: 29 http://deb.debian.org/debian unstable/main amd64 gettext-base amd64 0.22.5-2 [200 kB] Get: 30 http://deb.debian.org/debian unstable/main amd64 libuchardet0 amd64 0.0.8-1+b2 [68.9 kB] Get: 31 http://deb.debian.org/debian unstable/main amd64 groff-base amd64 1.23.0-5 [1181 kB] Get: 32 http://deb.debian.org/debian unstable/main amd64 bsdextrautils amd64 2.40.2-11 [91.5 kB] Get: 33 http://deb.debian.org/debian unstable/main amd64 libpipeline1 amd64 1.5.8-1 [42.0 kB] Get: 34 http://deb.debian.org/debian unstable/main amd64 man-db amd64 2.13.0-1 [1420 kB] Get: 35 http://deb.debian.org/debian unstable/main amd64 libantlr4-runtime4.9 amd64 4.9+dfsg-3+b2 [355 kB] Get: 36 http://deb.debian.org/debian unstable/main amd64 libicu72 amd64 72.1-5+b1 [9423 kB] Get: 37 http://deb.debian.org/debian unstable/main amd64 libxml2 amd64 2.12.7+dfsg+really2.9.14-0.2+b1 [699 kB] Get: 38 http://deb.debian.org/debian unstable/main amd64 afdko-bin amd64 4.0.1+dfsg1-2 [1137 kB] Get: 39 http://deb.debian.org/debian unstable/main amd64 m4 amd64 1.4.19-4 [287 kB] Get: 40 http://deb.debian.org/debian unstable/main amd64 autoconf all 2.72-3 [493 kB] Get: 41 http://deb.debian.org/debian unstable/main amd64 autotools-dev all 20220109.1 [51.6 kB] Get: 42 http://deb.debian.org/debian unstable/main amd64 automake all 1:1.16.5-1.3 [823 kB] Get: 43 http://deb.debian.org/debian unstable/main amd64 autopoint all 0.22.5-2 [723 kB] Get: 44 http://deb.debian.org/debian unstable/main amd64 libdebhelper-perl all 13.20 [89.7 kB] Get: 45 http://deb.debian.org/debian unstable/main amd64 libtool all 2.4.7-8 [517 kB] Get: 46 http://deb.debian.org/debian unstable/main amd64 dh-autoreconf all 20 [17.1 kB] Get: 47 http://deb.debian.org/debian unstable/main amd64 libarchive-zip-perl all 1.68-1 [104 kB] Get: 48 http://deb.debian.org/debian unstable/main amd64 libfile-stripnondeterminism-perl all 1.14.0-1 [19.5 kB] Get: 49 http://deb.debian.org/debian unstable/main amd64 dh-strip-nondeterminism all 1.14.0-1 [8448 B] Get: 50 http://deb.debian.org/debian unstable/main amd64 libelf1t64 amd64 0.192-4 [189 kB] Get: 51 http://deb.debian.org/debian unstable/main amd64 dwz amd64 0.15-1+b1 [110 kB] Get: 52 http://deb.debian.org/debian unstable/main amd64 gettext amd64 0.22.5-2 [1601 kB] Get: 53 http://deb.debian.org/debian unstable/main amd64 intltool-debian all 0.35.0+20060710.6 [22.9 kB] Get: 54 http://deb.debian.org/debian unstable/main amd64 po-debconf all 1.0.21+nmu1 [248 kB] Get: 55 http://deb.debian.org/debian unstable/main amd64 debhelper all 13.20 [915 kB] Get: 56 http://deb.debian.org/debian unstable/main amd64 python3-autocommand all 2.2.2-3 [13.6 kB] Get: 57 http://deb.debian.org/debian unstable/main amd64 python3-more-itertools all 10.5.0-1 [63.8 kB] Get: 58 http://deb.debian.org/debian unstable/main amd64 python3-typing-extensions all 4.12.2-2 [73.0 kB] Get: 59 http://deb.debian.org/debian unstable/main amd64 python3-typeguard all 4.4.1-1 [37.0 kB] Get: 60 http://deb.debian.org/debian unstable/main amd64 python3-inflect all 7.3.1-2 [32.4 kB] Get: 61 http://deb.debian.org/debian unstable/main amd64 python3-jaraco.context all 6.0.0-1 [7984 B] Get: 62 http://deb.debian.org/debian unstable/main amd64 python3-jaraco.functools all 4.1.0-1 [12.0 kB] Get: 63 http://deb.debian.org/debian unstable/main amd64 python3-pkg-resources all 75.2.0-1 [213 kB] Get: 64 http://deb.debian.org/debian unstable/main amd64 python3-jaraco.text all 4.0.0-1 [11.4 kB] Get: 65 http://deb.debian.org/debian unstable/main amd64 python3-zipp all 3.21.0-1 [10.6 kB] Get: 66 http://deb.debian.org/debian unstable/main amd64 python3-setuptools all 75.2.0-1 [731 kB] Get: 67 http://deb.debian.org/debian unstable/main amd64 dh-python all 6.20241024 [109 kB] Get: 68 http://deb.debian.org/debian unstable/main amd64 libblas3 amd64 3.12.0-4 [152 kB] Get: 69 http://deb.debian.org/debian unstable/main amd64 libgfortran5 amd64 14.2.0-8 [836 kB] Get: 70 http://deb.debian.org/debian unstable/main amd64 libjs-jquery all 3.6.1+dfsg+~3.5.14-1 [326 kB] Get: 71 http://deb.debian.org/debian unstable/main amd64 libjs-underscore all 1.13.4~dfsg+~1.11.4-3 [116 kB] Get: 72 http://deb.debian.org/debian unstable/main amd64 libjs-sphinxdoc all 7.4.7-4 [158 kB] Get: 73 http://deb.debian.org/debian unstable/main amd64 liblapack3 amd64 3.12.0-4 [2450 kB] Get: 74 http://deb.debian.org/debian unstable/main amd64 liblbfgsb0 amd64 3.0+dfsg.4-1+b2 [29.4 kB] Get: 75 http://deb.debian.org/debian unstable/main amd64 libpython3.13-stdlib amd64 3.13.0-2 [1992 kB] Get: 76 http://deb.debian.org/debian unstable/main amd64 libxslt1.1 amd64 1.1.35-1.1+b1 [233 kB] Get: 77 http://deb.debian.org/debian unstable/main amd64 python3.13 amd64 3.13.0-2 [730 kB] Get: 78 http://deb.debian.org/debian unstable/main amd64 python3-all amd64 3.12.7-1 [1052 B] Get: 79 http://deb.debian.org/debian unstable/main amd64 python3-appdirs all 1.4.4-4 [12.5 kB] Get: 80 http://deb.debian.org/debian unstable/main amd64 python3-attr all 24.2.0-1 [68.4 kB] Get: 81 http://deb.debian.org/debian unstable/main amd64 python3-brotli amd64 1.1.0-2+b6 [321 kB] Get: 82 http://deb.debian.org/debian unstable/main amd64 python3-tz all 2024.1-2 [30.9 kB] Get: 83 http://deb.debian.org/debian unstable/main amd64 python3-six all 1.16.0-7 [16.4 kB] Get: 84 http://deb.debian.org/debian unstable/main amd64 python3-fs all 2.4.16-4 [95.4 kB] Get: 85 http://deb.debian.org/debian unstable/main amd64 python3-lxml amd64 5.3.0-1+b1 [1676 kB] Get: 86 http://deb.debian.org/debian unstable/main amd64 python3-lz4 amd64 4.0.2+dfsg-1+b5 [25.6 kB] Get: 87 http://deb.debian.org/debian unstable/main amd64 python3-decorator all 5.1.1-5 [15.1 kB] Get: 88 http://deb.debian.org/debian unstable/main amd64 python3-numpy amd64 1:1.26.4+ds-12 [4738 kB] Get: 89 http://deb.debian.org/debian unstable/main amd64 python3-scipy amd64 1.14.1-2 [20.5 MB] Get: 90 http://deb.debian.org/debian unstable/main amd64 python3-mpmath all 1.3.0-1 [419 kB] Get: 91 http://deb.debian.org/debian unstable/main amd64 python3-sympy all 1.13.3-1 [4147 kB] Get: 92 http://deb.debian.org/debian unstable/main amd64 python3-ufolib2 all 0.16.1+dfsg1-1 [32.9 kB] Get: 93 http://deb.debian.org/debian unstable/main amd64 python3-defcon all 0.10.3-3 [189 kB] Get: 94 http://deb.debian.org/debian unstable/main amd64 unicode-data all 15.1.0-1 [8547 kB] Get: 95 http://deb.debian.org/debian unstable/main amd64 python3-fonttools amd64 4.55.0-3 [1634 kB] Get: 96 http://deb.debian.org/debian unstable/main amd64 python3-pyclipper amd64 1.3.0.post6-1+b1 [144 kB] Get: 97 http://deb.debian.org/debian unstable/main amd64 python3-booleanoperations all 0.9.0-3 [18.3 kB] Get: 98 http://deb.debian.org/debian unstable/main amd64 python3-cffsubr all 0.3.0-1 [9400 B] Get: 99 http://deb.debian.org/debian unstable/main amd64 python3-compreffor amd64 0.5.6-1+b1 [71.9 kB] Get: 100 http://deb.debian.org/debian unstable/main amd64 python3-fontmath all 0.9.4-1 [25.9 kB] Get: 101 http://deb.debian.org/debian unstable/main amd64 python3-iniconfig all 1.1.1-2 [6396 B] Get: 102 http://deb.debian.org/debian unstable/main amd64 python3-packaging all 24.2-1 [55.3 kB] Get: 103 http://deb.debian.org/debian unstable/main amd64 python3-pluggy all 1.5.0-1 [26.9 kB] Get: 104 http://deb.debian.org/debian unstable/main amd64 python3-pytest all 8.3.3-1 [249 kB] Get: 105 http://deb.debian.org/debian unstable/main amd64 python3-setuptools-scm all 8.1.0-1 [40.5 kB] Get: 106 http://deb.debian.org/debian unstable/main amd64 python3-syrupy all 4.7.2-1 [53.0 kB] Fetched 82.8 MB in 19s (4337 kB/s) debconf: delaying package configuration, since apt-utils is not installed Selecting previously unselected package libpython3.12-minimal:amd64. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 19966 files and directories currently installed.) Preparing to unpack .../libpython3.12-minimal_3.12.7-3_amd64.deb ... Unpacking libpython3.12-minimal:amd64 (3.12.7-3) ... Selecting previously unselected package libexpat1:amd64. Preparing to unpack .../libexpat1_2.6.4-1_amd64.deb ... Unpacking libexpat1:amd64 (2.6.4-1) ... Selecting previously unselected package python3.12-minimal. Preparing to unpack .../python3.12-minimal_3.12.7-3_amd64.deb ... Unpacking python3.12-minimal (3.12.7-3) ... Setting up libpython3.12-minimal:amd64 (3.12.7-3) ... Setting up libexpat1:amd64 (2.6.4-1) ... Setting up python3.12-minimal (3.12.7-3) ... Selecting previously unselected package python3-minimal. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 20286 files and directories currently installed.) Preparing to unpack .../00-python3-minimal_3.12.7-1_amd64.deb ... Unpacking python3-minimal (3.12.7-1) ... Selecting previously unselected package media-types. Preparing to unpack .../01-media-types_10.1.0_all.deb ... Unpacking media-types (10.1.0) ... Selecting previously unselected package netbase. Preparing to unpack .../02-netbase_6.4_all.deb ... Unpacking netbase (6.4) ... Selecting previously unselected package tzdata. Preparing to unpack .../03-tzdata_2024b-3_all.deb ... Unpacking tzdata (2024b-3) ... Selecting previously unselected package libkrb5support0:amd64. Preparing to unpack .../04-libkrb5support0_1.21.3-3_amd64.deb ... Unpacking libkrb5support0:amd64 (1.21.3-3) ... Selecting previously unselected package libcom-err2:amd64. Preparing to unpack .../05-libcom-err2_1.47.1-1+b1_amd64.deb ... Unpacking libcom-err2:amd64 (1.47.1-1+b1) ... Selecting previously unselected package libk5crypto3:amd64. Preparing to unpack .../06-libk5crypto3_1.21.3-3_amd64.deb ... Unpacking libk5crypto3:amd64 (1.21.3-3) ... Selecting previously unselected package libkeyutils1:amd64. Preparing to unpack .../07-libkeyutils1_1.6.3-4_amd64.deb ... Unpacking libkeyutils1:amd64 (1.6.3-4) ... Selecting previously unselected package libkrb5-3:amd64. Preparing to unpack .../08-libkrb5-3_1.21.3-3_amd64.deb ... Unpacking libkrb5-3:amd64 (1.21.3-3) ... Selecting previously unselected package libgssapi-krb5-2:amd64. Preparing to unpack .../09-libgssapi-krb5-2_1.21.3-3_amd64.deb ... Unpacking libgssapi-krb5-2:amd64 (1.21.3-3) ... Selecting previously unselected package libtirpc-common. Preparing to unpack .../10-libtirpc-common_1.3.4+ds-1.3_all.deb ... Unpacking libtirpc-common (1.3.4+ds-1.3) ... Selecting previously unselected package libtirpc3t64:amd64. Preparing to unpack .../11-libtirpc3t64_1.3.4+ds-1.3+b1_amd64.deb ... Adding 'diversion of /lib/x86_64-linux-gnu/libtirpc.so.3 to /lib/x86_64-linux-gnu/libtirpc.so.3.usr-is-merged by libtirpc3t64' Adding 'diversion of /lib/x86_64-linux-gnu/libtirpc.so.3.0.0 to /lib/x86_64-linux-gnu/libtirpc.so.3.0.0.usr-is-merged by libtirpc3t64' Unpacking libtirpc3t64:amd64 (1.3.4+ds-1.3+b1) ... Selecting previously unselected package libnsl2:amd64. Preparing to unpack .../12-libnsl2_1.3.0-3+b3_amd64.deb ... Unpacking libnsl2:amd64 (1.3.0-3+b3) ... Selecting previously unselected package readline-common. Preparing to unpack .../13-readline-common_8.2-5_all.deb ... Unpacking readline-common (8.2-5) ... Selecting previously unselected package libreadline8t64:amd64. Preparing to unpack .../14-libreadline8t64_8.2-5_amd64.deb ... Adding 'diversion of /lib/x86_64-linux-gnu/libhistory.so.8 to /lib/x86_64-linux-gnu/libhistory.so.8.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/x86_64-linux-gnu/libhistory.so.8.2 to /lib/x86_64-linux-gnu/libhistory.so.8.2.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/x86_64-linux-gnu/libreadline.so.8 to /lib/x86_64-linux-gnu/libreadline.so.8.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/x86_64-linux-gnu/libreadline.so.8.2 to /lib/x86_64-linux-gnu/libreadline.so.8.2.usr-is-merged by libreadline8t64' Unpacking libreadline8t64:amd64 (8.2-5) ... Selecting previously unselected package libpython3.12-stdlib:amd64. Preparing to unpack .../15-libpython3.12-stdlib_3.12.7-3_amd64.deb ... Unpacking libpython3.12-stdlib:amd64 (3.12.7-3) ... Selecting previously unselected package python3.12. Preparing to unpack .../16-python3.12_3.12.7-3_amd64.deb ... Unpacking python3.12 (3.12.7-3) ... Selecting previously unselected package libpython3-stdlib:amd64. Preparing to unpack .../17-libpython3-stdlib_3.12.7-1_amd64.deb ... Unpacking libpython3-stdlib:amd64 (3.12.7-1) ... Setting up python3-minimal (3.12.7-1) ... Selecting previously unselected package python3. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 21348 files and directories currently installed.) Preparing to unpack .../00-python3_3.12.7-1_amd64.deb ... Unpacking python3 (3.12.7-1) ... Selecting previously unselected package libpython3.13-minimal:amd64. Preparing to unpack .../01-libpython3.13-minimal_3.13.0-2_amd64.deb ... Unpacking libpython3.13-minimal:amd64 (3.13.0-2) ... Selecting previously unselected package python3.13-minimal. Preparing to unpack .../02-python3.13-minimal_3.13.0-2_amd64.deb ... Unpacking python3.13-minimal (3.13.0-2) ... Selecting previously unselected package sensible-utils. Preparing to unpack .../03-sensible-utils_0.0.24_all.deb ... Unpacking sensible-utils (0.0.24) ... Selecting previously unselected package libmagic-mgc. Preparing to unpack .../04-libmagic-mgc_1%3a5.45-3+b1_amd64.deb ... Unpacking libmagic-mgc (1:5.45-3+b1) ... Selecting previously unselected package libmagic1t64:amd64. Preparing to unpack .../05-libmagic1t64_1%3a5.45-3+b1_amd64.deb ... Unpacking libmagic1t64:amd64 (1:5.45-3+b1) ... Selecting previously unselected package file. Preparing to unpack .../06-file_1%3a5.45-3+b1_amd64.deb ... Unpacking file (1:5.45-3+b1) ... Selecting previously unselected package gettext-base. Preparing to unpack .../07-gettext-base_0.22.5-2_amd64.deb ... Unpacking gettext-base (0.22.5-2) ... Selecting previously unselected package libuchardet0:amd64. Preparing to unpack .../08-libuchardet0_0.0.8-1+b2_amd64.deb ... Unpacking libuchardet0:amd64 (0.0.8-1+b2) ... Selecting previously unselected package groff-base. Preparing to unpack .../09-groff-base_1.23.0-5_amd64.deb ... Unpacking groff-base (1.23.0-5) ... Selecting previously unselected package bsdextrautils. Preparing to unpack .../10-bsdextrautils_2.40.2-11_amd64.deb ... Unpacking bsdextrautils (2.40.2-11) ... Selecting previously unselected package libpipeline1:amd64. Preparing to unpack .../11-libpipeline1_1.5.8-1_amd64.deb ... Unpacking libpipeline1:amd64 (1.5.8-1) ... Selecting previously unselected package man-db. Preparing to unpack .../12-man-db_2.13.0-1_amd64.deb ... Unpacking man-db (2.13.0-1) ... Selecting previously unselected package libantlr4-runtime4.9:amd64. Preparing to unpack .../13-libantlr4-runtime4.9_4.9+dfsg-3+b2_amd64.deb ... Unpacking libantlr4-runtime4.9:amd64 (4.9+dfsg-3+b2) ... Selecting previously unselected package libicu72:amd64. Preparing to unpack .../14-libicu72_72.1-5+b1_amd64.deb ... Unpacking libicu72:amd64 (72.1-5+b1) ... Selecting previously unselected package libxml2:amd64. Preparing to unpack .../15-libxml2_2.12.7+dfsg+really2.9.14-0.2+b1_amd64.deb ... Unpacking libxml2:amd64 (2.12.7+dfsg+really2.9.14-0.2+b1) ... Selecting previously unselected package afdko-bin. Preparing to unpack .../16-afdko-bin_4.0.1+dfsg1-2_amd64.deb ... Unpacking afdko-bin (4.0.1+dfsg1-2) ... Selecting previously unselected package m4. Preparing to unpack .../17-m4_1.4.19-4_amd64.deb ... Unpacking m4 (1.4.19-4) ... Selecting previously unselected package autoconf. Preparing to unpack .../18-autoconf_2.72-3_all.deb ... Unpacking autoconf (2.72-3) ... Selecting previously unselected package autotools-dev. Preparing to unpack .../19-autotools-dev_20220109.1_all.deb ... Unpacking autotools-dev (20220109.1) ... Selecting previously unselected package automake. Preparing to unpack .../20-automake_1%3a1.16.5-1.3_all.deb ... Unpacking automake (1:1.16.5-1.3) ... Selecting previously unselected package autopoint. Preparing to unpack .../21-autopoint_0.22.5-2_all.deb ... Unpacking autopoint (0.22.5-2) ... Selecting previously unselected package libdebhelper-perl. Preparing to unpack .../22-libdebhelper-perl_13.20_all.deb ... Unpacking libdebhelper-perl (13.20) ... Selecting previously unselected package libtool. Preparing to unpack .../23-libtool_2.4.7-8_all.deb ... Unpacking libtool (2.4.7-8) ... Selecting previously unselected package dh-autoreconf. Preparing to unpack .../24-dh-autoreconf_20_all.deb ... Unpacking dh-autoreconf (20) ... Selecting previously unselected package libarchive-zip-perl. Preparing to unpack .../25-libarchive-zip-perl_1.68-1_all.deb ... Unpacking libarchive-zip-perl (1.68-1) ... Selecting previously unselected package libfile-stripnondeterminism-perl. Preparing to unpack .../26-libfile-stripnondeterminism-perl_1.14.0-1_all.deb ... Unpacking libfile-stripnondeterminism-perl (1.14.0-1) ... Selecting previously unselected package dh-strip-nondeterminism. Preparing to unpack .../27-dh-strip-nondeterminism_1.14.0-1_all.deb ... Unpacking dh-strip-nondeterminism (1.14.0-1) ... Selecting previously unselected package libelf1t64:amd64. Preparing to unpack .../28-libelf1t64_0.192-4_amd64.deb ... Unpacking libelf1t64:amd64 (0.192-4) ... Selecting previously unselected package dwz. Preparing to unpack .../29-dwz_0.15-1+b1_amd64.deb ... Unpacking dwz (0.15-1+b1) ... Selecting previously unselected package gettext. Preparing to unpack .../30-gettext_0.22.5-2_amd64.deb ... Unpacking gettext (0.22.5-2) ... Selecting previously unselected package intltool-debian. Preparing to unpack .../31-intltool-debian_0.35.0+20060710.6_all.deb ... Unpacking intltool-debian (0.35.0+20060710.6) ... Selecting previously unselected package po-debconf. Preparing to unpack .../32-po-debconf_1.0.21+nmu1_all.deb ... Unpacking po-debconf (1.0.21+nmu1) ... Selecting previously unselected package debhelper. Preparing to unpack .../33-debhelper_13.20_all.deb ... Unpacking debhelper (13.20) ... Selecting previously unselected package python3-autocommand. Preparing to unpack .../34-python3-autocommand_2.2.2-3_all.deb ... Unpacking python3-autocommand (2.2.2-3) ... Selecting previously unselected package python3-more-itertools. Preparing to unpack .../35-python3-more-itertools_10.5.0-1_all.deb ... Unpacking python3-more-itertools (10.5.0-1) ... Selecting previously unselected package python3-typing-extensions. Preparing to unpack .../36-python3-typing-extensions_4.12.2-2_all.deb ... Unpacking python3-typing-extensions (4.12.2-2) ... Selecting previously unselected package python3-typeguard. Preparing to unpack .../37-python3-typeguard_4.4.1-1_all.deb ... Unpacking python3-typeguard (4.4.1-1) ... Selecting previously unselected package python3-inflect. Preparing to unpack .../38-python3-inflect_7.3.1-2_all.deb ... Unpacking python3-inflect (7.3.1-2) ... Selecting previously unselected package python3-jaraco.context. Preparing to unpack .../39-python3-jaraco.context_6.0.0-1_all.deb ... Unpacking python3-jaraco.context (6.0.0-1) ... Selecting previously unselected package python3-jaraco.functools. Preparing to unpack .../40-python3-jaraco.functools_4.1.0-1_all.deb ... Unpacking python3-jaraco.functools (4.1.0-1) ... Selecting previously unselected package python3-pkg-resources. Preparing to unpack .../41-python3-pkg-resources_75.2.0-1_all.deb ... Unpacking python3-pkg-resources (75.2.0-1) ... Selecting previously unselected package python3-jaraco.text. Preparing to unpack .../42-python3-jaraco.text_4.0.0-1_all.deb ... Unpacking python3-jaraco.text (4.0.0-1) ... Selecting previously unselected package python3-zipp. Preparing to unpack .../43-python3-zipp_3.21.0-1_all.deb ... Unpacking python3-zipp (3.21.0-1) ... Selecting previously unselected package python3-setuptools. Preparing to unpack .../44-python3-setuptools_75.2.0-1_all.deb ... Unpacking python3-setuptools (75.2.0-1) ... Selecting previously unselected package dh-python. Preparing to unpack .../45-dh-python_6.20241024_all.deb ... Unpacking dh-python (6.20241024) ... Selecting previously unselected package libblas3:amd64. Preparing to unpack .../46-libblas3_3.12.0-4_amd64.deb ... Unpacking libblas3:amd64 (3.12.0-4) ... Selecting previously unselected package libgfortran5:amd64. Preparing to unpack .../47-libgfortran5_14.2.0-8_amd64.deb ... Unpacking libgfortran5:amd64 (14.2.0-8) ... Selecting previously unselected package libjs-jquery. Preparing to unpack .../48-libjs-jquery_3.6.1+dfsg+~3.5.14-1_all.deb ... Unpacking libjs-jquery (3.6.1+dfsg+~3.5.14-1) ... Selecting previously unselected package libjs-underscore. Preparing to unpack .../49-libjs-underscore_1.13.4~dfsg+~1.11.4-3_all.deb ... Unpacking libjs-underscore (1.13.4~dfsg+~1.11.4-3) ... Selecting previously unselected package libjs-sphinxdoc. Preparing to unpack .../50-libjs-sphinxdoc_7.4.7-4_all.deb ... Unpacking libjs-sphinxdoc (7.4.7-4) ... Selecting previously unselected package liblapack3:amd64. Preparing to unpack .../51-liblapack3_3.12.0-4_amd64.deb ... Unpacking liblapack3:amd64 (3.12.0-4) ... Selecting previously unselected package liblbfgsb0:amd64. Preparing to unpack .../52-liblbfgsb0_3.0+dfsg.4-1+b2_amd64.deb ... Unpacking liblbfgsb0:amd64 (3.0+dfsg.4-1+b2) ... Selecting previously unselected package libpython3.13-stdlib:amd64. Preparing to unpack .../53-libpython3.13-stdlib_3.13.0-2_amd64.deb ... Unpacking libpython3.13-stdlib:amd64 (3.13.0-2) ... Selecting previously unselected package libxslt1.1:amd64. Preparing to unpack .../54-libxslt1.1_1.1.35-1.1+b1_amd64.deb ... Unpacking libxslt1.1:amd64 (1.1.35-1.1+b1) ... Selecting previously unselected package python3.13. Preparing to unpack .../55-python3.13_3.13.0-2_amd64.deb ... Unpacking python3.13 (3.13.0-2) ... Selecting previously unselected package python3-all. Preparing to unpack .../56-python3-all_3.12.7-1_amd64.deb ... Unpacking python3-all (3.12.7-1) ... Selecting previously unselected package python3-appdirs. Preparing to unpack .../57-python3-appdirs_1.4.4-4_all.deb ... Unpacking python3-appdirs (1.4.4-4) ... Selecting previously unselected package python3-attr. Preparing to unpack .../58-python3-attr_24.2.0-1_all.deb ... Unpacking python3-attr (24.2.0-1) ... Selecting previously unselected package python3-brotli. Preparing to unpack .../59-python3-brotli_1.1.0-2+b6_amd64.deb ... Unpacking python3-brotli (1.1.0-2+b6) ... Selecting previously unselected package python3-tz. Preparing to unpack .../60-python3-tz_2024.1-2_all.deb ... Unpacking python3-tz (2024.1-2) ... Selecting previously unselected package python3-six. Preparing to unpack .../61-python3-six_1.16.0-7_all.deb ... Unpacking python3-six (1.16.0-7) ... Selecting previously unselected package python3-fs. Preparing to unpack .../62-python3-fs_2.4.16-4_all.deb ... Unpacking python3-fs (2.4.16-4) ... Selecting previously unselected package python3-lxml:amd64. Preparing to unpack .../63-python3-lxml_5.3.0-1+b1_amd64.deb ... Unpacking python3-lxml:amd64 (5.3.0-1+b1) ... Selecting previously unselected package python3-lz4. Preparing to unpack .../64-python3-lz4_4.0.2+dfsg-1+b5_amd64.deb ... Unpacking python3-lz4 (4.0.2+dfsg-1+b5) ... Selecting previously unselected package python3-decorator. Preparing to unpack .../65-python3-decorator_5.1.1-5_all.deb ... Unpacking python3-decorator (5.1.1-5) ... Selecting previously unselected package python3-numpy. Preparing to unpack .../66-python3-numpy_1%3a1.26.4+ds-12_amd64.deb ... Unpacking python3-numpy (1:1.26.4+ds-12) ... Selecting previously unselected package python3-scipy. Preparing to unpack .../67-python3-scipy_1.14.1-2_amd64.deb ... Unpacking python3-scipy (1.14.1-2) ... Selecting previously unselected package python3-mpmath. Preparing to unpack .../68-python3-mpmath_1.3.0-1_all.deb ... Unpacking python3-mpmath (1.3.0-1) ... Selecting previously unselected package python3-sympy. Preparing to unpack .../69-python3-sympy_1.13.3-1_all.deb ... Unpacking python3-sympy (1.13.3-1) ... Selecting previously unselected package python3-ufolib2. Preparing to unpack .../70-python3-ufolib2_0.16.1+dfsg1-1_all.deb ... Unpacking python3-ufolib2 (0.16.1+dfsg1-1) ... Selecting previously unselected package python3-defcon. Preparing to unpack .../71-python3-defcon_0.10.3-3_all.deb ... Unpacking python3-defcon (0.10.3-3) ... Selecting previously unselected package unicode-data. Preparing to unpack .../72-unicode-data_15.1.0-1_all.deb ... Unpacking unicode-data (15.1.0-1) ... Selecting previously unselected package python3-fonttools. Preparing to unpack .../73-python3-fonttools_4.55.0-3_amd64.deb ... Unpacking python3-fonttools (4.55.0-3) ... Selecting previously unselected package python3-pyclipper. Preparing to unpack .../74-python3-pyclipper_1.3.0.post6-1+b1_amd64.deb ... Unpacking python3-pyclipper (1.3.0.post6-1+b1) ... Selecting previously unselected package python3-booleanoperations. Preparing to unpack .../75-python3-booleanoperations_0.9.0-3_all.deb ... Unpacking python3-booleanoperations (0.9.0-3) ... Selecting previously unselected package python3-cffsubr. Preparing to unpack .../76-python3-cffsubr_0.3.0-1_all.deb ... Unpacking python3-cffsubr (0.3.0-1) ... Selecting previously unselected package python3-compreffor. Preparing to unpack .../77-python3-compreffor_0.5.6-1+b1_amd64.deb ... Unpacking python3-compreffor (0.5.6-1+b1) ... Selecting previously unselected package python3-fontmath. Preparing to unpack .../78-python3-fontmath_0.9.4-1_all.deb ... Unpacking python3-fontmath (0.9.4-1) ... Selecting previously unselected package python3-iniconfig. Preparing to unpack .../79-python3-iniconfig_1.1.1-2_all.deb ... Unpacking python3-iniconfig (1.1.1-2) ... Selecting previously unselected package python3-packaging. Preparing to unpack .../80-python3-packaging_24.2-1_all.deb ... Unpacking python3-packaging (24.2-1) ... Selecting previously unselected package python3-pluggy. Preparing to unpack .../81-python3-pluggy_1.5.0-1_all.deb ... Unpacking python3-pluggy (1.5.0-1) ... Selecting previously unselected package python3-pytest. Preparing to unpack .../82-python3-pytest_8.3.3-1_all.deb ... Unpacking python3-pytest (8.3.3-1) ... Selecting previously unselected package python3-setuptools-scm. Preparing to unpack .../83-python3-setuptools-scm_8.1.0-1_all.deb ... Unpacking python3-setuptools-scm (8.1.0-1) ... Selecting previously unselected package python3-syrupy. Preparing to unpack .../84-python3-syrupy_4.7.2-1_all.deb ... Unpacking python3-syrupy (4.7.2-1) ... Setting up media-types (10.1.0) ... Setting up libpipeline1:amd64 (1.5.8-1) ... Setting up libkeyutils1:amd64 (1.6.3-4) ... Setting up libicu72:amd64 (72.1-5+b1) ... Setting up bsdextrautils (2.40.2-11) ... Setting up libmagic-mgc (1:5.45-3+b1) ... Setting up libantlr4-runtime4.9:amd64 (4.9+dfsg-3+b2) ... Setting up libarchive-zip-perl (1.68-1) ... Setting up libtirpc-common (1.3.4+ds-1.3) ... Setting up libdebhelper-perl (13.20) ... Setting up libmagic1t64:amd64 (1:5.45-3+b1) ... Setting up gettext-base (0.22.5-2) ... Setting up m4 (1.4.19-4) ... Setting up libcom-err2:amd64 (1.47.1-1+b1) ... Setting up file (1:5.45-3+b1) ... Setting up libelf1t64:amd64 (0.192-4) ... Setting up libkrb5support0:amd64 (1.21.3-3) ... Setting up tzdata (2024b-3) ... Current default time zone: 'Etc/UTC' Local time is now: Sun Nov 24 19:25:46 UTC 2024. Universal Time is now: Sun Nov 24 19:25:46 UTC 2024. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up unicode-data (15.1.0-1) ... Setting up libpython3.13-minimal:amd64 (3.13.0-2) ... Setting up autotools-dev (20220109.1) ... Setting up libblas3:amd64 (3.12.0-4) ... update-alternatives: using /usr/lib/x86_64-linux-gnu/blas/libblas.so.3 to provide /usr/lib/x86_64-linux-gnu/libblas.so.3 (libblas.so.3-x86_64-linux-gnu) in auto mode Setting up autopoint (0.22.5-2) ... Setting up libk5crypto3:amd64 (1.21.3-3) ... Setting up libgfortran5:amd64 (14.2.0-8) ... Setting up autoconf (2.72-3) ... Setting up dwz (0.15-1+b1) ... Setting up sensible-utils (0.0.24) ... Setting up libuchardet0:amd64 (0.0.8-1+b2) ... Setting up python3.13-minimal (3.13.0-2) ... Setting up netbase (6.4) ... Setting up libkrb5-3:amd64 (1.21.3-3) ... Setting up libjs-jquery (3.6.1+dfsg+~3.5.14-1) ... Setting up readline-common (8.2-5) ... Setting up libxml2:amd64 (2.12.7+dfsg+really2.9.14-0.2+b1) ... Setting up libjs-underscore (1.13.4~dfsg+~1.11.4-3) ... Setting up automake (1:1.16.5-1.3) ... update-alternatives: using /usr/bin/automake-1.16 to provide /usr/bin/automake (automake) in auto mode Setting up libfile-stripnondeterminism-perl (1.14.0-1) ... Setting up liblapack3:amd64 (3.12.0-4) ... update-alternatives: using /usr/lib/x86_64-linux-gnu/lapack/liblapack.so.3 to provide /usr/lib/x86_64-linux-gnu/liblapack.so.3 (liblapack.so.3-x86_64-linux-gnu) in auto mode Setting up gettext (0.22.5-2) ... Setting up libtool (2.4.7-8) ... Setting up intltool-debian (0.35.0+20060710.6) ... Setting up dh-autoreconf (20) ... Setting up libgssapi-krb5-2:amd64 (1.21.3-3) ... Setting up libjs-sphinxdoc (7.4.7-4) ... Setting up libreadline8t64:amd64 (8.2-5) ... Setting up dh-strip-nondeterminism (1.14.0-1) ... Setting up groff-base (1.23.0-5) ... Setting up libxslt1.1:amd64 (1.1.35-1.1+b1) ... Setting up afdko-bin (4.0.1+dfsg1-2) ... Setting up libpython3.13-stdlib:amd64 (3.13.0-2) ... Setting up liblbfgsb0:amd64 (3.0+dfsg.4-1+b2) ... Setting up libtirpc3t64:amd64 (1.3.4+ds-1.3+b1) ... Setting up python3.13 (3.13.0-2) ... Setting up po-debconf (1.0.21+nmu1) ... Setting up man-db (2.13.0-1) ... Not building database; man-db/auto-update is not 'true'. Setting up libnsl2:amd64 (1.3.0-3+b3) ... Setting up libpython3.12-stdlib:amd64 (3.12.7-3) ... Setting up python3.12 (3.12.7-3) ... Setting up debhelper (13.20) ... Setting up libpython3-stdlib:amd64 (3.12.7-1) ... Setting up python3 (3.12.7-1) ... Setting up python3-zipp (3.21.0-1) ... Setting up python3-autocommand (2.2.2-3) ... Setting up python3-tz (2024.1-2) ... Setting up python3-six (1.16.0-7) ... Setting up python3-decorator (5.1.1-5) ... Setting up python3-packaging (24.2-1) ... Setting up python3-brotli (1.1.0-2+b6) ... Setting up python3-typing-extensions (4.12.2-2) ... Setting up python3-pluggy (1.5.0-1) ... Setting up python3-lxml:amd64 (5.3.0-1+b1) ... Setting up python3-mpmath (1.3.0-1) ... Setting up python3-appdirs (1.4.4-4) ... Setting up python3-pyclipper (1.3.0.post6-1+b1) ... Setting up python3-more-itertools (10.5.0-1) ... Setting up python3-iniconfig (1.1.1-2) ... Setting up python3-sympy (1.13.3-1) ... Setting up python3-attr (24.2.0-1) ... Setting up python3-jaraco.functools (4.1.0-1) ... Setting up python3-jaraco.context (6.0.0-1) ... Setting up python3-lz4 (4.0.2+dfsg-1+b5) ... Setting up python3-pytest (8.3.3-1) ... Setting up python3-syrupy (4.7.2-1) ... Setting up python3-typeguard (4.4.1-1) ... Setting up python3-all (3.12.7-1) ... Setting up python3-inflect (7.3.1-2) ... Setting up python3-jaraco.text (4.0.0-1) ... Setting up python3-pkg-resources (75.2.0-1) ... Setting up python3-setuptools (75.2.0-1) ... Setting up python3-setuptools-scm (8.1.0-1) ... Setting up python3-fs (2.4.16-4) ... Setting up python3-numpy (1:1.26.4+ds-12) ... Setting up dh-python (6.20241024) ... Setting up python3-scipy (1.14.1-2) ... Setting up python3-defcon (0.10.3-3) ... Setting up python3-fonttools (4.55.0-3) ... Setting up python3-ufolib2 (0.16.1+dfsg1-1) ... Setting up python3-fontmath (0.9.4-1) ... Setting up python3-cffsubr (0.3.0-1) ... Setting up python3-booleanoperations (0.9.0-3) ... Setting up python3-compreffor (0.5.6-1+b1) ... Processing triggers for libc-bin (2.40-4) ... Reading package lists... Building dependency tree... Reading state information... Reading extended state information... Initializing package states... Writing extended state information... Building tag database... -> Finished parsing the build-deps Reading package lists... Building dependency tree... Reading state information... fakeroot is already the newest version (1.36-1). 0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. I: Building the package I: Running cd /build/reproducible-path/ufo2ft-3.3.1/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-genchanges -S > ../ufo2ft_3.3.1-2_source.changes dpkg-buildpackage: info: source package ufo2ft dpkg-buildpackage: info: source version 3.3.1-2 dpkg-buildpackage: info: source distribution unstable dpkg-buildpackage: info: source changed by Boyuan Yang dpkg-source --before-build . dpkg-buildpackage: info: host architecture amd64 fakeroot debian/rules clean dh clean --buildsystem=pybuild debian/rules override_dh_auto_clean make[1]: Entering directory '/build/reproducible-path/ufo2ft-3.3.1' dh_auto_clean I: pybuild base:311: python3.13 setup.py clean /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running clean removing '/build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build' (and everything under it) 'build/bdist.linux-x86_64' does not exist -- can't clean it 'build/scripts-3.13' does not exist -- can't clean it I: pybuild base:311: python3.12 setup.py clean /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running clean removing '/build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build' (and everything under it) 'build/bdist.linux-x86_64' does not exist -- can't clean it 'build/scripts-3.12' does not exist -- can't clean it rm Lib/ufo2ft/_version.py make[1]: Leaving directory '/build/reproducible-path/ufo2ft-3.3.1' dh_autoreconf_clean -O--buildsystem=pybuild dh_clean -O--buildsystem=pybuild debian/rules build dh build --buildsystem=pybuild dh_update_autotools_config -O--buildsystem=pybuild dh_autoreconf -O--buildsystem=pybuild dh_auto_configure -O--buildsystem=pybuild I: pybuild base:311: python3.13 setup.py config /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running config I: pybuild base:311: python3.12 setup.py config /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running config dh_auto_build -O--buildsystem=pybuild I: pybuild base:311: /usr/bin/python3.13 setup.py build /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running build running build_py creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters running egg_info creating Lib/ufo2ft.egg-info writing Lib/ufo2ft.egg-info/PKG-INFO writing dependency_links to Lib/ufo2ft.egg-info/dependency_links.txt writing requirements to Lib/ufo2ft.egg-info/requires.txt writing top-level names to Lib/ufo2ft.egg-info/top_level.txt writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' adding license file 'LICENSE' writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' I: pybuild base:311: /usr/bin/python3 setup.py build /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running build running build_py creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters running egg_info writing Lib/ufo2ft.egg-info/PKG-INFO writing dependency_links to Lib/ufo2ft.egg-info/dependency_links.txt writing requirements to Lib/ufo2ft.egg-info/requires.txt writing top-level names to Lib/ufo2ft.egg-info/top_level.txt reading manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' adding license file 'LICENSE' writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' debian/rules override_dh_auto_test make[1]: Entering directory '/build/reproducible-path/ufo2ft-3.3.1' # For experimental build, allow failures dh_auto_test I: pybuild base:311: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build; python3.13 -m pytest tests ============================= test session starts ============================== platform linux -- Python 3.13.0, pytest-8.3.3, pluggy-1.5.0 rootdir: /build/reproducible-path/ufo2ft-3.3.1 configfile: setup.cfg plugins: syrupy-4.7.2, typeguard-4.4.1 collected 1140 items tests/featureCompiler_test.py ................ [ 1%] tests/featureWriters/cursFeatureWriter_test.py ......... [ 2%] tests/featureWriters/featureWriters_test.py ........ [ 2%] tests/featureWriters/gdefFeatureWriter_test.py .......... [ 3%] tests/featureWriters/kernFeatureWriter2_test.py ........................ [ 5%] ....F..... [ 6%] tests/featureWriters/kernFeatureWriter_test.py ......................... [ 8%] ......F..... [ 10%] tests/featureWriters/markFeatureWriter_test.py ......................... [ 12%] ............ [ 13%] tests/featureWriters/variableFeatureWriter_test.py .. [ 13%] tests/filters/decomposeComponents_test.py ...... [ 13%] tests/filters/decomposeTransformedComponents_test.py ... [ 14%] tests/filters/dottedCircle_test.py ... [ 14%] tests/filters/explodeColorLayerGlyphs_test.py . [ 14%] tests/filters/flattenComponents_test.py ........ [ 15%] tests/filters/propagateAnchors_test.py ............... [ 16%] tests/filters/sortContours_test.py .... [ 16%] tests/filters/transformations_test.py ............................... [ 19%] tests/fontInfoData_test.py ................ [ 21%] tests/infoCompiler_test.py ....... [ 21%] tests/instantiator_test.py ........................... [ 24%] tests/instructionCompiler_test.py ...................................... [ 27%] ......... [ 28%] tests/integration_test.py ......s.s.............FFFFFFF...FF.....FF..... [ 32%] ..............FF. [ 33%] tests/outlineCompiler_test.py .......................................... [ 37%] ........................................................................ [ 43%] ........................ [ 45%] tests/preProcessor_test.py ....s......s.............. [ 48%] tests/util_test.py . [ 48%] tests/featureCompiler_test.py ................ [ 49%] tests/featureWriters/cursFeatureWriter_test.py ......... [ 50%] tests/featureWriters/featureWriters_test.py ........ [ 51%] tests/featureWriters/gdefFeatureWriter_test.py .......... [ 51%] tests/featureWriters/kernFeatureWriter2_test.py ........................ [ 54%] ....F..... [ 54%] tests/featureWriters/kernFeatureWriter_test.py ......................... [ 57%] ......F..... [ 58%] tests/featureWriters/markFeatureWriter_test.py ......................... [ 60%] ............ [ 61%] tests/featureWriters/variableFeatureWriter_test.py .. [ 61%] tests/filters/decomposeComponents_test.py ...... [ 62%] tests/filters/decomposeTransformedComponents_test.py ... [ 62%] tests/filters/dottedCircle_test.py ... [ 62%] tests/filters/explodeColorLayerGlyphs_test.py . [ 62%] tests/filters/flattenComponents_test.py ........ [ 63%] tests/filters/propagateAnchors_test.py ............... [ 64%] tests/filters/sortContours_test.py .... [ 65%] tests/filters/transformations_test.py ............................... [ 67%] tests/fontInfoData_test.py ................ [ 69%] tests/infoCompiler_test.py ....... [ 69%] tests/instantiator_test.py ........................... [ 72%] tests/instructionCompiler_test.py ...................................... [ 75%] ......... [ 76%] tests/integration_test.py ......s.s.............FFFFFFF...FF.....FF..... [ 80%] ..............FF. [ 81%] tests/outlineCompiler_test.py .......................................... [ 85%] ........................................................................ [ 91%] ........................ [ 93%] tests/preProcessor_test.py ....s......s.............. [ 96%] tests/util_test.py . [ 96%] tests/featureWriters/ast_test.py . [ 96%] tests/featureWriters/markFeatureWriter_test.py ......... [ 97%] tests/filters/filters_test.py ................... [ 98%] tests/filters/transformations_test.py . [ 98%] tests/fontInfoData_test.py .. [ 99%] tests/instantiator_test.py .... [ 99%] tests/instructionCompiler_test.py .... [ 99%] tests/util_test.py .. [100%] =================================== FAILURES =================================== _________________________ test_kern_zyyy_zinh[defcon] __________________________ snapshot = ''' lookup kern_dflt { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni0310 uni0310 1; pos uni03...a; language dflt; lookup kern_dflt; script dupl; language dflt; lookup kern_dflt; } dist; ''' FontClass = def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert newFeatures.asFea() == snapshot E AssertionError: assert [+ received] == [- snapshot] E ''' E ... E lookupflag IgnoreMarks; E - pos uni0300 uni0300 0; E - pos uni0310 uni0310 1; E - pos uni0320 uni0320 2; E - pos uni0330 uni0330 3;... E E ...Full output truncated (85 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[defcon] __________________________ FontClass = def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert dedent(str(newFeatures)) == dedent( """\ lookup kern_Deva { lookupflag IgnoreMarks; pos uni1CD0 uni1CD0 7; pos uni1CE0 uni1CE0 8; pos uni1CF0 uni1CF0 9; pos uni20F0 uni20F0 11; pos uniA830 uniA830 34; } kern_Deva; lookup kern_Dupl { lookupflag IgnoreMarks; pos uni1BCA0 uni1BCA0 42; } kern_Dupl; lookup kern_Grek { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni1DC0 uni1DC0 10; } kern_Grek; lookup kern_Hani_Hrkt { lookupflag IgnoreMarks; pos uni1D360 uni1D360 43; pos uni1D370 uni1D370 44; pos uni1F250 uni1F250 45; pos uni2FF0 uni2FF0 13; pos uni3010 uni3010 14; pos uni3030 uni3030 15; pos uni30A0 uni30A0 16; pos uni3190 uni3190 17; pos uni31C0 uni31C0 18; pos uni31D0 uni31D0 19; pos uni31E0 uni31E0 20; pos uni3220 uni3220 21; pos uni3230 uni3230 22; pos uni3240 uni3240 23; pos uni3280 uni3280 24; pos uni3290 uni3290 25; pos uni32A0 uni32A0 26; pos uni32B0 uni32B0 27; pos uni32C0 uni32C0 28; pos uni3360 uni3360 29; pos uni3370 uni3370 30; pos uni33E0 uni33E0 31; pos uni33F0 uni33F0 32; pos uniA700 uniA700 33; pos uniFF70 uniFF70 35; } kern_Hani_Hrkt; lookup kern_Default { lookupflag IgnoreMarks; pos uni0310 uni0310 1; pos uni0320 uni0320 2; pos uni0330 uni0330 3; pos uni0640 uni0640 4; pos uni0650 uni0650 5; pos uni0670 uni0670 6; pos uni10100 uni10100 36; pos uni10110 uni10110 37; pos uni10120 uni10120 38; pos uni10130 uni10130 39; pos uni102E0 uni102E0 40; pos uni102F0 uni102F0 41; pos uni2E30 uni2E30 12; } kern_Default; feature kern { script DFLT; language dflt; lookup kern_Default; lookup kern_Grek; lookup kern_Hani_Hrkt; script grek; language dflt; lookup kern_Default; lookup kern_Grek; script hani; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; script kana; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; } kern; feature dist { script dev2; language dflt; lookup kern_Default; lookup kern_Deva; script deva; language dflt; lookup kern_Default; lookup kern_Deva; script dupl; language dflt; lookup kern_Default; lookup kern_Dupl; } dist; """ ) E AssertionError: assert 'lookup kern_...l;\n} dist;\n' == 'lookup kern_...l;\n} dist;\n' E E Skipping 61 identical leading characters in diff, use -v to show E - 0 uni1CD0 7; E ? ^ E + 0 uni1CD0 3; E ? ^ E - pos uni1CE0 uni1CE0 8;... E E ...Full output truncated (218 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError _____________ IntegrationTest.test_compileVariableTTF[defcon-None] _____________ self = designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _____________ IntegrationTest.test_compileVariableTTF[defcon-True] _____________ self = designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-useProductionNames.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[defcon-False] _____________ self = designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-None] _____________ self = designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-True] _____________ self = designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-useProductionNames.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-False] ____________ self = designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ________ IntegrationTest.test_compileVariableCFF2_subroutinized[defcon] ________ self = designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) > expectTTX(varfont, "TestVariableFont-CFF2-cffsubr.ttx") tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-cffsubr.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ self = designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-post3.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ self = designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-post3.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _______________ IntegrationTest.test_compileVariableTTFs[defcon] _______________ self = designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-TTF.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-TTF.ttx", ) tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-TTF.ttx +++ @@ -251,99 +251,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -417,42 +324,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -635,17 +539,17 @@ - + - + - + @@ -654,7 +558,7 @@ - + @@ -671,7 +575,7 @@ - + @@ -688,13 +592,13 @@ - + - + @@ -702,7 +606,7 @@ - + @@ -710,7 +614,7 @@ - + @@ -718,7 +622,7 @@ - + @@ -726,7 +630,7 @@ - + @@ -734,13 +638,13 @@ - + - + ______________ IntegrationTest.test_compileVariableCFF2s[defcon] _______________ self = designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-CFF2.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx", ) tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx +++ @@ -128,99 +128,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -294,42 +201,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -692,17 +596,17 @@ - + - + - + @@ -711,7 +615,7 @@ - + @@ -728,7 +632,7 @@ - + @@ -745,13 +649,13 @@ - + - + @@ -759,7 +663,7 @@ - + @@ -767,7 +671,7 @@ - + @@ -775,7 +679,7 @@ - + @@ -783,7 +687,7 @@ - + @@ -791,13 +695,13 @@ - + - + _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableTTFs] ______ self = FontClass = compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableCFF2s] _____ self = FontClass = compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ snapshot = ''' lookup kern_dflt { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni0310 uni0310 1; pos uni03...a; language dflt; lookup kern_dflt; script dupl; language dflt; lookup kern_dflt; } dist; ''' FontClass = .ctor at 0x7f2cd9daade0> def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert newFeatures.asFea() == snapshot E AssertionError: assert [+ received] == [- snapshot] E ''' E ... E lookupflag IgnoreMarks; E - pos uni0300 uni0300 0; E - pos uni0310 uni0310 1; E - pos uni0320 uni0320 2; E - pos uni0330 uni0330 3;... E E ...Full output truncated (85 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ FontClass = .ctor at 0x7f2cd9daade0> def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert dedent(str(newFeatures)) == dedent( """\ lookup kern_Deva { lookupflag IgnoreMarks; pos uni1CD0 uni1CD0 7; pos uni1CE0 uni1CE0 8; pos uni1CF0 uni1CF0 9; pos uni20F0 uni20F0 11; pos uniA830 uniA830 34; } kern_Deva; lookup kern_Dupl { lookupflag IgnoreMarks; pos uni1BCA0 uni1BCA0 42; } kern_Dupl; lookup kern_Grek { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni1DC0 uni1DC0 10; } kern_Grek; lookup kern_Hani_Hrkt { lookupflag IgnoreMarks; pos uni1D360 uni1D360 43; pos uni1D370 uni1D370 44; pos uni1F250 uni1F250 45; pos uni2FF0 uni2FF0 13; pos uni3010 uni3010 14; pos uni3030 uni3030 15; pos uni30A0 uni30A0 16; pos uni3190 uni3190 17; pos uni31C0 uni31C0 18; pos uni31D0 uni31D0 19; pos uni31E0 uni31E0 20; pos uni3220 uni3220 21; pos uni3230 uni3230 22; pos uni3240 uni3240 23; pos uni3280 uni3280 24; pos uni3290 uni3290 25; pos uni32A0 uni32A0 26; pos uni32B0 uni32B0 27; pos uni32C0 uni32C0 28; pos uni3360 uni3360 29; pos uni3370 uni3370 30; pos uni33E0 uni33E0 31; pos uni33F0 uni33F0 32; pos uniA700 uniA700 33; pos uniFF70 uniFF70 35; } kern_Hani_Hrkt; lookup kern_Default { lookupflag IgnoreMarks; pos uni0310 uni0310 1; pos uni0320 uni0320 2; pos uni0330 uni0330 3; pos uni0640 uni0640 4; pos uni0650 uni0650 5; pos uni0670 uni0670 6; pos uni10100 uni10100 36; pos uni10110 uni10110 37; pos uni10120 uni10120 38; pos uni10130 uni10130 39; pos uni102E0 uni102E0 40; pos uni102F0 uni102F0 41; pos uni2E30 uni2E30 12; } kern_Default; feature kern { script DFLT; language dflt; lookup kern_Default; lookup kern_Grek; lookup kern_Hani_Hrkt; script grek; language dflt; lookup kern_Default; lookup kern_Grek; script hani; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; script kana; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; } kern; feature dist { script dev2; language dflt; lookup kern_Default; lookup kern_Deva; script deva; language dflt; lookup kern_Default; lookup kern_Deva; script dupl; language dflt; lookup kern_Default; lookup kern_Dupl; } dist; """ ) E AssertionError: assert 'lookup kern_...l;\n} dist;\n' == 'lookup kern_...l;\n} dist;\n' E E Skipping 61 identical leading characters in diff, use -v to show E - 0 uni1CD0 7; E ? ^ E + 0 uni1CD0 3; E ? ^ E - pos uni1CE0 uni1CE0 8;... E E ...Full output truncated (218 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-None] _____________ self = designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-True] _____________ self = designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-useProductionNames.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-False] ____________ self = designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-None] ____________ self = designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-True] ____________ self = designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-useProductionNames.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ___________ IntegrationTest.test_compileVariableCFF2[ufoLib2-False] ____________ self = designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _______ IntegrationTest.test_compileVariableCFF2_subroutinized[ufoLib2] ________ self = designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) > expectTTX(varfont, "TestVariableFont-CFF2-cffsubr.ttx") tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-cffsubr.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ self = designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-post3.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ self = designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-post3.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ______________ IntegrationTest.test_compileVariableTTFs[ufoLib2] _______________ self = designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-TTF.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-TTF.ttx", ) tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-TTF.ttx +++ @@ -251,99 +251,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -417,42 +324,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -635,17 +539,17 @@ - + - + - + @@ -654,7 +558,7 @@ - + @@ -671,7 +575,7 @@ - + @@ -688,13 +592,13 @@ - + - + @@ -702,7 +606,7 @@ - + @@ -710,7 +614,7 @@ - + @@ -718,7 +622,7 @@ - + @@ -726,7 +630,7 @@ - + @@ -734,13 +638,13 @@ - + - + ______________ IntegrationTest.test_compileVariableCFF2s[ufoLib2] ______________ self = designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-CFF2.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx", ) tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx +++ @@ -128,99 +128,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -294,42 +201,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -692,17 +596,17 @@ - + - + - + @@ -711,7 +615,7 @@ - + @@ -728,7 +632,7 @@ - + @@ -745,13 +649,13 @@ - + - + @@ -759,7 +663,7 @@ - + @@ -767,7 +671,7 @@ - + @@ -775,7 +679,7 @@ - + @@ -783,7 +687,7 @@ - + @@ -791,13 +695,13 @@ - + - + _____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableTTFs] _____ self = FontClass = .ctor at 0x7f2cd9daade0> compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont ____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableCFF2s] _____ self = FontClass = .ctor at 0x7f2cd9daade0> compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont =============================== warnings summary =============================== .pybuild/cpython3_3.13_ufo2ft/build/tests/filters/dottedCircle_test.py::test_empty_font_deprecated[defcon] /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py:8: UserWarning: The dottedCircleFilter module is deprecated, please import dottedCircle instead. warnings.warn( .pybuild/cpython3_3.13_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_none[defcon-cff2] .pybuild/cpython3_3.13_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_specialize[defcon-cff2] .pybuild/cpython3_3.13_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_none[ufoLib2-cff2] .pybuild/cpython3_3.13_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_specialize[ufoLib2-cff2] /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/postProcessor.py:333: UserWarning: 'convertCFFtoCFF2' is deprecated; Use fontTools.cffLib.CFFToCFF2.convertCFFToCFF2 instead. convertCFFtoCFF2(otf) -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html --------------------------- snapshot report summary ---------------------------- 1 snapshot failed. 40 snapshots passed. =========================== short test summary info ============================ SKIPPED [2] tests/integration_test.py:137: skia-pathops is unavailable in debian yet SKIPPED [2] tests/integration_test.py:146: skia-pathops is unavailable in debian yet SKIPPED [2] tests/preProcessor_test.py:94: skia-pathops is unavailable in debian yet SKIPPED [2] tests/preProcessor_test.py:214: skia-pathops is unavailable in debian yet FAILED tests/featureWriters/kernFeatureWriter2_test.py::test_kern_zyyy_zinh[defcon] FAILED tests/featureWriters/kernFeatureWriter_test.py::test_kern_zyyy_zinh[defcon] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2_subroutinized[defcon] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTFs[defcon] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[defcon] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[defcon-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[defcon-compileVariableCFF2s] FAILED tests/featureWriters/kernFeatureWriter2_test.py::test_kern_zyyy_zinh[ufoLib2] FAILED tests/featureWriters/kernFeatureWriter_test.py::test_kern_zyyy_zinh[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2_subroutinized[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTFs[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableCFF2s] ====== 30 failed, 1102 passed, 8 skipped, 5 warnings in 112.45s (0:01:52) ====== E: pybuild pybuild:389: test: plugin distutils failed with: exit code=1: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build; python3.13 -m pytest tests I: pybuild base:311: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build; python3.12 -m pytest tests ============================= test session starts ============================== platform linux -- Python 3.12.7, pytest-8.3.3, pluggy-1.5.0 rootdir: /build/reproducible-path/ufo2ft-3.3.1 configfile: setup.cfg plugins: syrupy-4.7.2, typeguard-4.4.1 collected 1140 items tests/featureCompiler_test.py ................ [ 1%] tests/featureWriters/cursFeatureWriter_test.py ......... [ 2%] tests/featureWriters/featureWriters_test.py ........ [ 2%] tests/featureWriters/gdefFeatureWriter_test.py .......... [ 3%] tests/featureWriters/kernFeatureWriter2_test.py ........................ [ 5%] ....F..... [ 6%] tests/featureWriters/kernFeatureWriter_test.py ......................... [ 8%] ......F..... [ 10%] tests/featureWriters/markFeatureWriter_test.py ......................... [ 12%] ............ [ 13%] tests/featureWriters/variableFeatureWriter_test.py .. [ 13%] tests/filters/decomposeComponents_test.py ...... [ 13%] tests/filters/decomposeTransformedComponents_test.py ... [ 14%] tests/filters/dottedCircle_test.py ... [ 14%] tests/filters/explodeColorLayerGlyphs_test.py . [ 14%] tests/filters/flattenComponents_test.py ........ [ 15%] tests/filters/propagateAnchors_test.py ............... [ 16%] tests/filters/sortContours_test.py .... [ 16%] tests/filters/transformations_test.py ............................... [ 19%] tests/fontInfoData_test.py ................ [ 21%] tests/infoCompiler_test.py ....... [ 21%] tests/instantiator_test.py ........................... [ 24%] tests/instructionCompiler_test.py ...................................... [ 27%] ......... [ 28%] tests/integration_test.py ......s.s.............FFFFFFF...FF.....FF..... [ 32%] ..............FF. [ 33%] tests/outlineCompiler_test.py .......................................... [ 37%] ........................................................................ [ 43%] ........................ [ 45%] tests/preProcessor_test.py ....s......s.............. [ 48%] tests/util_test.py . [ 48%] tests/featureCompiler_test.py ................ [ 49%] tests/featureWriters/cursFeatureWriter_test.py ......... [ 50%] tests/featureWriters/featureWriters_test.py ........ [ 51%] tests/featureWriters/gdefFeatureWriter_test.py .......... [ 51%] tests/featureWriters/kernFeatureWriter2_test.py ........................ [ 54%] ....F..... [ 54%] tests/featureWriters/kernFeatureWriter_test.py ......................... [ 57%] ......F..... [ 58%] tests/featureWriters/markFeatureWriter_test.py ......................... [ 60%] ............ [ 61%] tests/featureWriters/variableFeatureWriter_test.py .. [ 61%] tests/filters/decomposeComponents_test.py ...... [ 62%] tests/filters/decomposeTransformedComponents_test.py ... [ 62%] tests/filters/dottedCircle_test.py ... [ 62%] tests/filters/explodeColorLayerGlyphs_test.py . [ 62%] tests/filters/flattenComponents_test.py ........ [ 63%] tests/filters/propagateAnchors_test.py ............... [ 64%] tests/filters/sortContours_test.py .... [ 65%] tests/filters/transformations_test.py ............................... [ 67%] tests/fontInfoData_test.py ................ [ 69%] tests/infoCompiler_test.py ....... [ 69%] tests/instantiator_test.py ........................... [ 72%] tests/instructionCompiler_test.py ...................................... [ 75%] ......... [ 76%] tests/integration_test.py ......s.s.............FFFFFFF...FF.....FF..... [ 80%] ..............FF. [ 81%] tests/outlineCompiler_test.py .......................................... [ 85%] ........................................................................ [ 91%] ........................ [ 93%] tests/preProcessor_test.py ....s......s.............. [ 96%] tests/util_test.py . [ 96%] tests/featureWriters/ast_test.py . [ 96%] tests/featureWriters/markFeatureWriter_test.py ......... [ 97%] tests/filters/filters_test.py ................... [ 98%] tests/filters/transformations_test.py . [ 98%] tests/fontInfoData_test.py .. [ 99%] tests/instantiator_test.py .... [ 99%] tests/instructionCompiler_test.py .... [ 99%] tests/util_test.py .. [100%] =================================== FAILURES =================================== _________________________ test_kern_zyyy_zinh[defcon] __________________________ snapshot = ''' lookup kern_dflt { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni0310 uni0310 1; pos uni03...a; language dflt; lookup kern_dflt; script dupl; language dflt; lookup kern_dflt; } dist; ''' FontClass = def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert newFeatures.asFea() == snapshot E AssertionError: assert [+ received] == [- snapshot] E ''' E ... E lookupflag IgnoreMarks; E - pos uni0300 uni0300 0; E - pos uni0310 uni0310 1; E - pos uni0320 uni0320 2; E - pos uni0330 uni0330 3;... E E ...Full output truncated (85 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[defcon] __________________________ FontClass = def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert dedent(str(newFeatures)) == dedent( """\ lookup kern_Deva { lookupflag IgnoreMarks; pos uni1CD0 uni1CD0 7; pos uni1CE0 uni1CE0 8; pos uni1CF0 uni1CF0 9; pos uni20F0 uni20F0 11; pos uniA830 uniA830 34; } kern_Deva; lookup kern_Dupl { lookupflag IgnoreMarks; pos uni1BCA0 uni1BCA0 42; } kern_Dupl; lookup kern_Grek { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni1DC0 uni1DC0 10; } kern_Grek; lookup kern_Hani_Hrkt { lookupflag IgnoreMarks; pos uni1D360 uni1D360 43; pos uni1D370 uni1D370 44; pos uni1F250 uni1F250 45; pos uni2FF0 uni2FF0 13; pos uni3010 uni3010 14; pos uni3030 uni3030 15; pos uni30A0 uni30A0 16; pos uni3190 uni3190 17; pos uni31C0 uni31C0 18; pos uni31D0 uni31D0 19; pos uni31E0 uni31E0 20; pos uni3220 uni3220 21; pos uni3230 uni3230 22; pos uni3240 uni3240 23; pos uni3280 uni3280 24; pos uni3290 uni3290 25; pos uni32A0 uni32A0 26; pos uni32B0 uni32B0 27; pos uni32C0 uni32C0 28; pos uni3360 uni3360 29; pos uni3370 uni3370 30; pos uni33E0 uni33E0 31; pos uni33F0 uni33F0 32; pos uniA700 uniA700 33; pos uniFF70 uniFF70 35; } kern_Hani_Hrkt; lookup kern_Default { lookupflag IgnoreMarks; pos uni0310 uni0310 1; pos uni0320 uni0320 2; pos uni0330 uni0330 3; pos uni0640 uni0640 4; pos uni0650 uni0650 5; pos uni0670 uni0670 6; pos uni10100 uni10100 36; pos uni10110 uni10110 37; pos uni10120 uni10120 38; pos uni10130 uni10130 39; pos uni102E0 uni102E0 40; pos uni102F0 uni102F0 41; pos uni2E30 uni2E30 12; } kern_Default; feature kern { script DFLT; language dflt; lookup kern_Default; lookup kern_Grek; lookup kern_Hani_Hrkt; script grek; language dflt; lookup kern_Default; lookup kern_Grek; script hani; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; script kana; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; } kern; feature dist { script dev2; language dflt; lookup kern_Default; lookup kern_Deva; script deva; language dflt; lookup kern_Default; lookup kern_Deva; script dupl; language dflt; lookup kern_Default; lookup kern_Dupl; } dist; """ ) E AssertionError: assert 'lookup kern_...l;\n} dist;\n' == 'lookup kern_...l;\n} dist;\n' E E Skipping 61 identical leading characters in diff, use -v to show E - 0 uni1CD0 7; E ? ^ E + 0 uni1CD0 3; E ? ^ E - pos uni1CE0 uni1CE0 8;... E E ...Full output truncated (218 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError _____________ IntegrationTest.test_compileVariableTTF[defcon-None] _____________ self = designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _____________ IntegrationTest.test_compileVariableTTF[defcon-True] _____________ self = designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-useProductionNames.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[defcon-False] _____________ self = designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-None] _____________ self = designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-True] _____________ self = designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-useProductionNames.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-False] ____________ self = designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ________ IntegrationTest.test_compileVariableCFF2_subroutinized[defcon] ________ self = designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) > expectTTX(varfont, "TestVariableFont-CFF2-cffsubr.ttx") tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-cffsubr.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ self = designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-post3.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ self = designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-post3.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _______________ IntegrationTest.test_compileVariableTTFs[defcon] _______________ self = designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-TTF.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-TTF.ttx", ) tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-TTF.ttx +++ @@ -251,99 +251,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -417,42 +324,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -635,17 +539,17 @@ - + - + - + @@ -654,7 +558,7 @@ - + @@ -671,7 +575,7 @@ - + @@ -688,13 +592,13 @@ - + - + @@ -702,7 +606,7 @@ - + @@ -710,7 +614,7 @@ - + @@ -718,7 +622,7 @@ - + @@ -726,7 +630,7 @@ - + @@ -734,13 +638,13 @@ - + - + ______________ IntegrationTest.test_compileVariableCFF2s[defcon] _______________ self = designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-CFF2.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx", ) tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx +++ @@ -128,99 +128,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -294,42 +201,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -692,17 +596,17 @@ - + - + - + @@ -711,7 +615,7 @@ - + @@ -728,7 +632,7 @@ - + @@ -745,13 +649,13 @@ - + - + @@ -759,7 +663,7 @@ - + @@ -767,7 +671,7 @@ - + @@ -775,7 +679,7 @@ - + @@ -783,7 +687,7 @@ - + @@ -791,13 +695,13 @@ - + - + _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableTTFs] ______ self = FontClass = compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableCFF2s] _____ self = FontClass = compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ snapshot = ''' lookup kern_dflt { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni0310 uni0310 1; pos uni03...a; language dflt; lookup kern_dflt; script dupl; language dflt; lookup kern_dflt; } dist; ''' FontClass = .ctor at 0x7ff561e9a020> def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert newFeatures.asFea() == snapshot E AssertionError: assert [+ received] == [- snapshot] E ''' E ... E lookupflag IgnoreMarks; E - pos uni0300 uni0300 0; E - pos uni0310 uni0310 1; E - pos uni0320 uni0320 2; E - pos uni0330 uni0330 3;... E E ...Full output truncated (85 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ FontClass = .ctor at 0x7ff561e9a020> def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert dedent(str(newFeatures)) == dedent( """\ lookup kern_Deva { lookupflag IgnoreMarks; pos uni1CD0 uni1CD0 7; pos uni1CE0 uni1CE0 8; pos uni1CF0 uni1CF0 9; pos uni20F0 uni20F0 11; pos uniA830 uniA830 34; } kern_Deva; lookup kern_Dupl { lookupflag IgnoreMarks; pos uni1BCA0 uni1BCA0 42; } kern_Dupl; lookup kern_Grek { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni1DC0 uni1DC0 10; } kern_Grek; lookup kern_Hani_Hrkt { lookupflag IgnoreMarks; pos uni1D360 uni1D360 43; pos uni1D370 uni1D370 44; pos uni1F250 uni1F250 45; pos uni2FF0 uni2FF0 13; pos uni3010 uni3010 14; pos uni3030 uni3030 15; pos uni30A0 uni30A0 16; pos uni3190 uni3190 17; pos uni31C0 uni31C0 18; pos uni31D0 uni31D0 19; pos uni31E0 uni31E0 20; pos uni3220 uni3220 21; pos uni3230 uni3230 22; pos uni3240 uni3240 23; pos uni3280 uni3280 24; pos uni3290 uni3290 25; pos uni32A0 uni32A0 26; pos uni32B0 uni32B0 27; pos uni32C0 uni32C0 28; pos uni3360 uni3360 29; pos uni3370 uni3370 30; pos uni33E0 uni33E0 31; pos uni33F0 uni33F0 32; pos uniA700 uniA700 33; pos uniFF70 uniFF70 35; } kern_Hani_Hrkt; lookup kern_Default { lookupflag IgnoreMarks; pos uni0310 uni0310 1; pos uni0320 uni0320 2; pos uni0330 uni0330 3; pos uni0640 uni0640 4; pos uni0650 uni0650 5; pos uni0670 uni0670 6; pos uni10100 uni10100 36; pos uni10110 uni10110 37; pos uni10120 uni10120 38; pos uni10130 uni10130 39; pos uni102E0 uni102E0 40; pos uni102F0 uni102F0 41; pos uni2E30 uni2E30 12; } kern_Default; feature kern { script DFLT; language dflt; lookup kern_Default; lookup kern_Grek; lookup kern_Hani_Hrkt; script grek; language dflt; lookup kern_Default; lookup kern_Grek; script hani; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; script kana; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; } kern; feature dist { script dev2; language dflt; lookup kern_Default; lookup kern_Deva; script deva; language dflt; lookup kern_Default; lookup kern_Deva; script dupl; language dflt; lookup kern_Default; lookup kern_Dupl; } dist; """ ) E AssertionError: assert 'lookup kern_...l;\n} dist;\n' == 'lookup kern_...l;\n} dist;\n' E E Skipping 61 identical leading characters in diff, use -v to show E - 0 uni1CD0 7; E ? ^ E + 0 uni1CD0 3; E ? ^ E - pos uni1CE0 uni1CE0 8;... E E ...Full output truncated (218 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-None] _____________ self = designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-True] _____________ self = designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-useProductionNames.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-False] ____________ self = designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-None] ____________ self = designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-True] ____________ self = designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-useProductionNames.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ___________ IntegrationTest.test_compileVariableCFF2[ufoLib2-False] ____________ self = designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _______ IntegrationTest.test_compileVariableCFF2_subroutinized[ufoLib2] ________ self = designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) > expectTTX(varfont, "TestVariableFont-CFF2-cffsubr.ttx") tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-cffsubr.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ self = designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-post3.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ self = designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-post3.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ______________ IntegrationTest.test_compileVariableTTFs[ufoLib2] _______________ self = designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-TTF.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-TTF.ttx", ) tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-TTF.ttx +++ @@ -251,99 +251,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -417,42 +324,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -635,17 +539,17 @@ - + - + - + @@ -654,7 +558,7 @@ - + @@ -671,7 +575,7 @@ - + @@ -688,13 +592,13 @@ - + - + @@ -702,7 +606,7 @@ - + @@ -710,7 +614,7 @@ - + @@ -718,7 +622,7 @@ - + @@ -726,7 +630,7 @@ - + @@ -734,13 +638,13 @@ - + - + ______________ IntegrationTest.test_compileVariableCFF2s[ufoLib2] ______________ self = designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-CFF2.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx", ) tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx +++ @@ -128,99 +128,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -294,42 +201,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -692,17 +596,17 @@ - + - + - + @@ -711,7 +615,7 @@ - + @@ -728,7 +632,7 @@ - + @@ -745,13 +649,13 @@ - + - + @@ -759,7 +663,7 @@ - + @@ -767,7 +671,7 @@ - + @@ -775,7 +679,7 @@ - + @@ -783,7 +687,7 @@ - + @@ -791,13 +695,13 @@ - + - + _____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableTTFs] _____ self = FontClass = .ctor at 0x7ff561e9a020> compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont ____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableCFF2s] _____ self = FontClass = .ctor at 0x7ff561e9a020> compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont =============================== warnings summary =============================== .pybuild/cpython3_3.12_ufo2ft/build/tests/filters/dottedCircle_test.py::test_empty_font_deprecated[defcon] /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py:8: UserWarning: The dottedCircleFilter module is deprecated, please import dottedCircle instead. warnings.warn( .pybuild/cpython3_3.12_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_none[defcon-cff2] .pybuild/cpython3_3.12_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_specialize[defcon-cff2] .pybuild/cpython3_3.12_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_none[ufoLib2-cff2] .pybuild/cpython3_3.12_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_specialize[ufoLib2-cff2] /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/postProcessor.py:333: UserWarning: 'convertCFFtoCFF2' is deprecated; Use fontTools.cffLib.CFFToCFF2.convertCFFToCFF2 instead. convertCFFtoCFF2(otf) -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html --------------------------- snapshot report summary ---------------------------- 1 snapshot failed. 40 snapshots passed. =========================== short test summary info ============================ SKIPPED [2] tests/integration_test.py:137: skia-pathops is unavailable in debian yet SKIPPED [2] tests/integration_test.py:146: skia-pathops is unavailable in debian yet SKIPPED [2] tests/preProcessor_test.py:94: skia-pathops is unavailable in debian yet SKIPPED [2] tests/preProcessor_test.py:214: skia-pathops is unavailable in debian yet FAILED tests/featureWriters/kernFeatureWriter2_test.py::test_kern_zyyy_zinh[defcon] FAILED tests/featureWriters/kernFeatureWriter_test.py::test_kern_zyyy_zinh[defcon] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2_subroutinized[defcon] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTFs[defcon] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[defcon] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[defcon-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[defcon-compileVariableCFF2s] FAILED tests/featureWriters/kernFeatureWriter2_test.py::test_kern_zyyy_zinh[ufoLib2] FAILED tests/featureWriters/kernFeatureWriter_test.py::test_kern_zyyy_zinh[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2_subroutinized[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTFs[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableCFF2s] ====== 30 failed, 1102 passed, 8 skipped, 5 warnings in 74.24s (0:01:14) ======= E: pybuild pybuild:389: test: plugin distutils failed with: exit code=1: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build; python3.12 -m pytest tests dh_auto_test: error: pybuild --test --test-pytest -i python{version} -p "3.13 3.12" returned exit code 13 make[1]: [debian/rules:15: override_dh_auto_test] Error 25 (ignored) make[1]: Leaving directory '/build/reproducible-path/ufo2ft-3.3.1' create-stamp debian/debhelper-build-stamp fakeroot debian/rules binary dh binary --buildsystem=pybuild dh_testroot -O--buildsystem=pybuild dh_prep -O--buildsystem=pybuild dh_auto_install --destdir=debian/python3-ufo2ft/ -O--buildsystem=pybuild I: pybuild base:311: /usr/bin/python3.13 setup.py install --root /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running install /usr/lib/python3/dist-packages/setuptools/_distutils/cmd.py:66: SetuptoolsDeprecationWarning: setup.py install is deprecated. !! ******************************************************************************** Please avoid running ``setup.py`` directly. Instead, use pypa/build, pypa/installer or other standards-based tools. See https://blog.ganssle.io/articles/2021/10/setup-py-deprecated.html for details. ******************************************************************************** !! self.initialize_options() running build running build_py copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft running egg_info writing Lib/ufo2ft.egg-info/PKG-INFO writing dependency_links to Lib/ufo2ft.egg-info/dependency_links.txt writing requirements to Lib/ufo2ft.egg-info/requires.txt writing top-level names to Lib/ufo2ft.egg-info/top_level.txt reading manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' adding license file 'LICENSE' writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' running install_lib creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/baseCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableTTFCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/ttfCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableTTFsCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableOTFCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableCFF2sCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/otfCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/cubicToQuadratic.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/propagateAnchors.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/explodeColorLayerGlyphs.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeTransformedComponents.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/reverseContourDirection.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/skipExportGlyphs.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/sortContours.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircleFilter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircle.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/base.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/transformations.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/removeOverlaps.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeComponents.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/flattenComponents.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/postProcessor.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/constants.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/outlineCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/instantiator.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/infoCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/fontInfoData.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/util.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/featureCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/instructionCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/errors.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/preProcessor.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/_version.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/baseFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/gdefFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/cursFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/ast.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter2.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/markFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/maxContextCalc.py to maxContextCalc.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/preProcessor.py to preProcessor.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/interpolatableTTFCompiler.py to interpolatableTTFCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/baseCompiler.py to baseCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/ttfCompiler.py to ttfCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/interpolatableOTFCompiler.py to interpolatableOTFCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/variableCFF2sCompiler.py to variableCFF2sCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/otfCompiler.py to otfCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/variableTTFsCompiler.py to variableTTFsCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/constants.py to constants.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/outlineCompiler.py to outlineCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_version.py to _version.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/removeOverlaps.py to removeOverlaps.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/skipExportGlyphs.py to skipExportGlyphs.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/reverseContourDirection.py to reverseContourDirection.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/explodeColorLayerGlyphs.py to explodeColorLayerGlyphs.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/decomposeTransformedComponents.py to decomposeTransformedComponents.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/flattenComponents.py to flattenComponents.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/dottedCircleFilter.py to dottedCircleFilter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/base.py to base.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__main__.py to __main__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/decomposeComponents.py to decomposeComponents.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/transformations.py to transformations.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/dottedCircle.py to dottedCircle.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/cubicToQuadratic.py to cubicToQuadratic.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/sortContours.py to sortContours.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/propagateAnchors.py to propagateAnchors.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/infoCompiler.py to infoCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/fontInfoData.py to fontInfoData.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/instantiator.py to instantiator.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/postProcessor.py to postProcessor.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/instructionCompiler.py to instructionCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/kernFeatureWriter2.py to kernFeatureWriter2.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/baseFeatureWriter.py to baseFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/ast.py to ast.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/cursFeatureWriter.py to cursFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/gdefFeatureWriter.py to gdefFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__main__.py to __main__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/markFeatureWriter.py to markFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/kernFeatureWriter.py to kernFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/util.py to util.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/errors.py to errors.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureCompiler.py to featureCompiler.cpython-313.pyc running install_egg_info Copying Lib/ufo2ft.egg-info to /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft-3.3.1.egg-info Skipping SOURCES.txt running install_scripts I: pybuild base:311: /usr/bin/python3 setup.py install --root /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running install /usr/lib/python3/dist-packages/setuptools/_distutils/cmd.py:66: SetuptoolsDeprecationWarning: setup.py install is deprecated. !! ******************************************************************************** Please avoid running ``setup.py`` directly. Instead, use pypa/build, pypa/installer or other standards-based tools. See https://blog.ganssle.io/articles/2021/10/setup-py-deprecated.html for details. ******************************************************************************** !! self.initialize_options() running build running build_py copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft running egg_info writing Lib/ufo2ft.egg-info/PKG-INFO writing dependency_links to Lib/ufo2ft.egg-info/dependency_links.txt writing requirements to Lib/ufo2ft.egg-info/requires.txt writing top-level names to Lib/ufo2ft.egg-info/top_level.txt reading manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' adding license file 'LICENSE' writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' running install_lib creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/otfCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableTTFsCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableOTFCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/ttfCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableTTFCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableCFF2sCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/baseCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/explodeColorLayerGlyphs.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircle.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/cubicToQuadratic.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeTransformedComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/propagateAnchors.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/base.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/flattenComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/reverseContourDirection.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/removeOverlaps.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/transformations.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/sortContours.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/skipExportGlyphs.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircleFilter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/outlineCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/preProcessor.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/errors.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/postProcessor.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/infoCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/instructionCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/fontInfoData.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/_version.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/featureCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/instantiator.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/constants.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/util.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter2.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/markFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/ast.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/gdefFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/baseFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/cursFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/maxContextCalc.py to maxContextCalc.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/preProcessor.py to preProcessor.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/interpolatableTTFCompiler.py to interpolatableTTFCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/baseCompiler.py to baseCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/ttfCompiler.py to ttfCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/interpolatableOTFCompiler.py to interpolatableOTFCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/variableCFF2sCompiler.py to variableCFF2sCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/otfCompiler.py to otfCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/variableTTFsCompiler.py to variableTTFsCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/constants.py to constants.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/outlineCompiler.py to outlineCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_version.py to _version.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/removeOverlaps.py to removeOverlaps.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/skipExportGlyphs.py to skipExportGlyphs.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/reverseContourDirection.py to reverseContourDirection.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/explodeColorLayerGlyphs.py to explodeColorLayerGlyphs.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/decomposeTransformedComponents.py to decomposeTransformedComponents.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/flattenComponents.py to flattenComponents.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/dottedCircleFilter.py to dottedCircleFilter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/base.py to base.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__main__.py to __main__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/decomposeComponents.py to decomposeComponents.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/transformations.py to transformations.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/dottedCircle.py to dottedCircle.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/cubicToQuadratic.py to cubicToQuadratic.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/sortContours.py to sortContours.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/propagateAnchors.py to propagateAnchors.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/infoCompiler.py to infoCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/fontInfoData.py to fontInfoData.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/instantiator.py to instantiator.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/postProcessor.py to postProcessor.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/instructionCompiler.py to instructionCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/kernFeatureWriter2.py to kernFeatureWriter2.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/baseFeatureWriter.py to baseFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/ast.py to ast.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/cursFeatureWriter.py to cursFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/gdefFeatureWriter.py to gdefFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__main__.py to __main__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/markFeatureWriter.py to markFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/kernFeatureWriter.py to kernFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/util.py to util.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/errors.py to errors.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureCompiler.py to featureCompiler.cpython-312.pyc running install_egg_info Copying Lib/ufo2ft.egg-info to /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft-3.3.1.egg-info Skipping SOURCES.txt running install_scripts dh_installdocs -O--buildsystem=pybuild dh_installchangelogs -O--buildsystem=pybuild dh_python3 -O--buildsystem=pybuild dh_installsystemduser -O--buildsystem=pybuild dh_perl -O--buildsystem=pybuild dh_link -O--buildsystem=pybuild dh_strip_nondeterminism -O--buildsystem=pybuild dh_compress -O--buildsystem=pybuild dh_fixperms -O--buildsystem=pybuild dh_missing -O--buildsystem=pybuild dh_installdeb -O--buildsystem=pybuild dh_gencontrol -O--buildsystem=pybuild dh_md5sums -O--buildsystem=pybuild dh_builddeb -O--buildsystem=pybuild dpkg-deb: building package 'python3-ufo2ft' in '../python3-ufo2ft_3.3.1-2_all.deb'. dpkg-genbuildinfo --build=binary -O../ufo2ft_3.3.1-2_amd64.buildinfo dpkg-genchanges --build=binary -O../ufo2ft_3.3.1-2_amd64.changes dpkg-genchanges: info: binary-only upload (no source code included) dpkg-source --after-build . dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: not including original source code in upload I: copying local configuration I: unmounting dev/ptmx filesystem I: unmounting dev/pts filesystem I: unmounting dev/shm filesystem I: unmounting proc filesystem I: unmounting sys filesystem I: cleaning the build env I: removing directory /srv/workspace/pbuilder/894615 and its subdirectories I: Current time: Sun Nov 24 07:33:14 -12 2024 I: pbuilder-time-stamp: 1732476794 Sun Nov 24 19:33:14 UTC 2024 I: Signing ./b1/ufo2ft_3.3.1-2_amd64.buildinfo as ufo2ft_3.3.1-2_amd64.buildinfo.asc Sun Nov 24 19:33:14 UTC 2024 I: Signed ./b1/ufo2ft_3.3.1-2_amd64.buildinfo as ./b1/ufo2ft_3.3.1-2_amd64.buildinfo.asc Sun Nov 24 19:33:14 UTC 2024 - build #1 for ufo2ft/unstable/amd64 on ionos11-amd64 done. Starting cleanup. All cleanup done. Sun Nov 24 19:33:14 UTC 2024 - reproducible_build.sh stopped running as /tmp/jenkins-script-wcYxy7nB, removing. /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf: total 16 drwxr-xr-x 2 jenkins jenkins 4096 Nov 24 19:33 b1 drwxr-xr-x 2 jenkins jenkins 4096 Nov 24 19:22 b2 -rw------- 1 jenkins jenkins 3602 Nov 24 19:22 rbuildlog.ltArHKm -rw-r--r-- 1 jenkins jenkins 2508 Oct 23 13:44 ufo2ft_3.3.1-2.dsc /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b1: total 524 -rw-r--r-- 1 jenkins jenkins 377074 Nov 24 19:33 build.log -rw-r--r-- 1 jenkins jenkins 114788 Nov 24 19:33 python3-ufo2ft_3.3.1-2_all.deb -rw-r--r-- 1 jenkins jenkins 6224 Nov 24 19:33 ufo2ft_3.3.1-2.debian.tar.xz -rw-r--r-- 1 jenkins jenkins 2508 Nov 24 19:33 ufo2ft_3.3.1-2.dsc -rw-r--r-- 1 jenkins jenkins 7281 Nov 24 19:33 ufo2ft_3.3.1-2_amd64.buildinfo -rw-r--r-- 1 jenkins jenkins 8163 Nov 24 19:33 ufo2ft_3.3.1-2_amd64.buildinfo.asc -rw-r--r-- 1 jenkins jenkins 1167 Nov 24 19:33 ufo2ft_3.3.1-2_amd64.changes -rw-r--r-- 1 jenkins jenkins 1294 Nov 24 19:33 ufo2ft_3.3.1-2_source.changes /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b2: total 0 Sun Nov 24 19:33:15 UTC 2024 I: Deleting $TMPDIR on ionos11-amd64.debian.net. I: pbuilder: network access will be disabled during build I: Current time: Sun Nov 24 07:22:45 -12 2024 I: pbuilder-time-stamp: 1732476165 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/unstable-reproducible-base.tgz] I: copying local configuration W: --override-config is not set; not updating apt.conf Read the manpage for details. I: mounting /proc filesystem I: mounting /sys filesystem I: creating /{dev,run}/shm I: mounting /dev/pts filesystem I: redirecting /dev/ptmx to /dev/pts/ptmx I: policy-rc.d already exists I: Copying source file I: copying [ufo2ft_3.3.1-2.dsc] I: copying [./ufo2ft_3.3.1.orig.tar.gz] I: copying [./ufo2ft_3.3.1-2.debian.tar.xz] I: Extracting source gpgv: Signature made Wed Oct 23 13:31:24 2024 gpgv: using RSA key 7E7729476D87D6F11D91ACCBC293E7B461825ACE gpgv: Can't check signature: No public key dpkg-source: warning: cannot verify inline signature for ./ufo2ft_3.3.1-2.dsc: no acceptable signature found dpkg-source: info: extracting ufo2ft in ufo2ft-3.3.1 dpkg-source: info: unpacking ufo2ft_3.3.1.orig.tar.gz dpkg-source: info: unpacking ufo2ft_3.3.1-2.debian.tar.xz dpkg-source: info: using patch list from debian/patches/series dpkg-source: info: applying disable-pathops-test.patch dpkg-source: info: applying Add-files-to-avoid-clean-target-failure.patch I: using fakeroot in build. I: Installing the build-deps I: user script /srv/workspace/pbuilder/894615/tmp/hooks/D02_print_environment starting I: set BUILDDIR='/build/reproducible-path' BUILDUSERGECOS='first user,first room,first work-phone,first home-phone,first other' BUILDUSERNAME='pbuilder1' BUILD_ARCH='amd64' DEBIAN_FRONTEND='noninteractive' DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=20 ' DISTRIBUTION='unstable' HOME='/root' HOST_ARCH='amd64' IFS=' ' INVOCATION_ID='8b467b916a84408090859ead7c9f7d87' LANG='C' LANGUAGE='en_US:en' LC_ALL='C' MAIL='/var/mail/root' OPTIND='1' PATH='/usr/sbin:/usr/bin:/sbin:/bin:/usr/games' PBCURRENTCOMMANDLINEOPERATION='build' PBUILDER_OPERATION='build' PBUILDER_PKGDATADIR='/usr/share/pbuilder' PBUILDER_PKGLIBDIR='/usr/lib/pbuilder' PBUILDER_SYSCONFDIR='/etc' PPID='894615' PS1='# ' PS2='> ' PS4='+ ' PWD='/' SHELL='/bin/bash' SHLVL='2' SUDO_COMMAND='/usr/bin/timeout -k 18.1h 18h /usr/bin/ionice -c 3 /usr/bin/nice /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/pbuilderrc_0MIM --distribution unstable --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b1 --logfile b1/build.log ufo2ft_3.3.1-2.dsc' SUDO_GID='111' SUDO_UID='106' SUDO_USER='jenkins' TERM='unknown' TZ='/usr/share/zoneinfo/Etc/GMT+12' USER='root' _='/usr/bin/systemd-run' http_proxy='http://46.16.76.132:3128' I: uname -a Linux ionos11-amd64 6.1.0-27-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.115-1 (2024-11-01) x86_64 GNU/Linux I: ls -l /bin lrwxrwxrwx 1 root root 7 Nov 22 14:40 /bin -> usr/bin I: user script /srv/workspace/pbuilder/894615/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy Version: 0.invalid.0 Architecture: amd64 Maintainer: Debian Pbuilder Team Description: Dummy package to satisfy dependencies with aptitude - created by pbuilder This package was created automatically by pbuilder to satisfy the build-dependencies of the package being currently built. Depends: debhelper-compat (= 13), dh-sequence-python3, python3-all, python3-setuptools, python3-setuptools-scm, python3-pytest, python3-fontmath, python3-fonttools (>= 4.50.0), python3-ufolib2 (>= 0.16.0), python3-defcon (>= 0.10.0), python3-syrupy, python3-compreffor (>= 0.5.5), python3-booleanoperations (>= 0.9.0), python3-cffsubr (>= 0.2.9) dpkg-deb: building package 'pbuilder-satisfydepends-dummy' in '/tmp/satisfydepends-aptitude/pbuilder-satisfydepends-dummy.deb'. Selecting previously unselected package pbuilder-satisfydepends-dummy. (Reading database ... 19966 files and directories currently installed.) Preparing to unpack .../pbuilder-satisfydepends-dummy.deb ... Unpacking pbuilder-satisfydepends-dummy (0.invalid.0) ... dpkg: pbuilder-satisfydepends-dummy: dependency problems, but configuring anyway as you requested: pbuilder-satisfydepends-dummy depends on debhelper-compat (= 13); however: Package debhelper-compat is not installed. pbuilder-satisfydepends-dummy depends on dh-sequence-python3; however: Package dh-sequence-python3 is not installed. pbuilder-satisfydepends-dummy depends on python3-all; however: Package python3-all is not installed. pbuilder-satisfydepends-dummy depends on python3-setuptools; however: Package python3-setuptools is not installed. pbuilder-satisfydepends-dummy depends on python3-setuptools-scm; however: Package python3-setuptools-scm is not installed. pbuilder-satisfydepends-dummy depends on python3-pytest; however: Package python3-pytest is not installed. pbuilder-satisfydepends-dummy depends on python3-fontmath; however: Package python3-fontmath is not installed. pbuilder-satisfydepends-dummy depends on python3-fonttools (>= 4.50.0); however: Package python3-fonttools is not installed. pbuilder-satisfydepends-dummy depends on python3-ufolib2 (>= 0.16.0); however: Package python3-ufolib2 is not installed. pbuilder-satisfydepends-dummy depends on python3-defcon (>= 0.10.0); however: Package python3-defcon is not installed. pbuilder-satisfydepends-dummy depends on python3-syrupy; however: Package python3-syrupy is not installed. pbuilder-satisfydepends-dummy depends on python3-compreffor (>= 0.5.5); however: Package python3-compreffor is not installed. pbuilder-satisfydepends-dummy depends on python3-booleanoperations (>= 0.9.0); however: Package python3-booleanoperations is not installed. pbuilder-satisfydepends-dummy depends on python3-cffsubr (>= 0.2.9); however: Package python3-cffsubr is not installed. Setting up pbuilder-satisfydepends-dummy (0.invalid.0) ... Reading package lists... Building dependency tree... Reading state information... Initializing package states... Writing extended state information... Building tag database... pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) The following NEW packages will be installed: afdko-bin{a} autoconf{a} automake{a} autopoint{a} autotools-dev{a} bsdextrautils{a} debhelper{a} dh-autoreconf{a} dh-python{a} dh-strip-nondeterminism{a} dwz{a} file{a} gettext{a} gettext-base{a} groff-base{a} intltool-debian{a} libantlr4-runtime4.9{a} libarchive-zip-perl{a} libblas3{a} libcom-err2{a} libdebhelper-perl{a} libelf1t64{a} libexpat1{a} libfile-stripnondeterminism-perl{a} libgfortran5{a} libgssapi-krb5-2{a} libicu72{a} libjs-jquery{a} libjs-sphinxdoc{a} libjs-underscore{a} libk5crypto3{a} libkeyutils1{a} libkrb5-3{a} libkrb5support0{a} liblapack3{a} liblbfgsb0{a} libmagic-mgc{a} libmagic1t64{a} libnsl2{a} libpipeline1{a} libpython3-stdlib{a} libpython3.12-minimal{a} libpython3.12-stdlib{a} libpython3.13-minimal{a} libpython3.13-stdlib{a} libreadline8t64{a} libtirpc-common{a} libtirpc3t64{a} libtool{a} libuchardet0{a} libxml2{a} libxslt1.1{a} m4{a} man-db{a} media-types{a} netbase{a} po-debconf{a} python3{a} python3-all{a} python3-appdirs{a} python3-attr{a} python3-autocommand{a} python3-booleanoperations{a} python3-brotli{a} python3-cffsubr{a} python3-compreffor{a} python3-decorator{a} python3-defcon{a} python3-fontmath{a} python3-fonttools{a} python3-fs{a} python3-inflect{a} python3-iniconfig{a} python3-jaraco.context{a} python3-jaraco.functools{a} python3-jaraco.text{a} python3-lxml{a} python3-lz4{a} python3-minimal{a} python3-more-itertools{a} python3-mpmath{a} python3-numpy{a} python3-packaging{a} python3-pkg-resources{a} python3-pluggy{a} python3-pyclipper{a} python3-pytest{a} python3-scipy{a} python3-setuptools{a} python3-setuptools-scm{a} python3-six{a} python3-sympy{a} python3-syrupy{a} python3-typeguard{a} python3-typing-extensions{a} python3-tz{a} python3-ufolib2{a} python3-zipp{a} python3.12{a} python3.12-minimal{a} python3.13{a} python3.13-minimal{a} readline-common{a} sensible-utils{a} tzdata{a} unicode-data{a} The following packages are RECOMMENDED but will NOT be installed: ca-certificates curl isympy-common javascript-common krb5-locales libarchive-cpio-perl libltdl-dev libmail-sendmail-perl lynx python3-bs4 python3-cssselect python3-fontpens python3-html5lib python3-pil python3-pooch python3-pygments wget 0 packages upgraded, 106 newly installed, 0 to remove and 0 not upgraded. Need to get 82.8 MB of archives. After unpacking 407 MB will be used. Writing extended state information... Get: 1 http://deb.debian.org/debian unstable/main amd64 libpython3.12-minimal amd64 3.12.7-3 [815 kB] Get: 2 http://deb.debian.org/debian unstable/main amd64 libexpat1 amd64 2.6.4-1 [106 kB] Get: 3 http://deb.debian.org/debian unstable/main amd64 python3.12-minimal amd64 3.12.7-3 [2162 kB] Get: 4 http://deb.debian.org/debian unstable/main amd64 python3-minimal amd64 3.12.7-1 [26.8 kB] Get: 5 http://deb.debian.org/debian unstable/main amd64 media-types all 10.1.0 [26.9 kB] Get: 6 http://deb.debian.org/debian unstable/main amd64 netbase all 6.4 [12.8 kB] Get: 7 http://deb.debian.org/debian unstable/main amd64 tzdata all 2024b-3 [255 kB] Get: 8 http://deb.debian.org/debian unstable/main amd64 libkrb5support0 amd64 1.21.3-3 [32.5 kB] Get: 9 http://deb.debian.org/debian unstable/main amd64 libcom-err2 amd64 1.47.1-1+b1 [23.2 kB] Get: 10 http://deb.debian.org/debian unstable/main amd64 libk5crypto3 amd64 1.21.3-3 [79.9 kB] Get: 11 http://deb.debian.org/debian unstable/main amd64 libkeyutils1 amd64 1.6.3-4 [9092 B] Get: 12 http://deb.debian.org/debian unstable/main amd64 libkrb5-3 amd64 1.21.3-3 [324 kB] Get: 13 http://deb.debian.org/debian unstable/main amd64 libgssapi-krb5-2 amd64 1.21.3-3 [136 kB] Get: 14 http://deb.debian.org/debian unstable/main amd64 libtirpc-common all 1.3.4+ds-1.3 [10.9 kB] Get: 15 http://deb.debian.org/debian unstable/main amd64 libtirpc3t64 amd64 1.3.4+ds-1.3+b1 [83.1 kB] Get: 16 http://deb.debian.org/debian unstable/main amd64 libnsl2 amd64 1.3.0-3+b3 [40.6 kB] Get: 17 http://deb.debian.org/debian unstable/main amd64 readline-common all 8.2-5 [69.3 kB] Get: 18 http://deb.debian.org/debian unstable/main amd64 libreadline8t64 amd64 8.2-5 [169 kB] Get: 19 http://deb.debian.org/debian unstable/main amd64 libpython3.12-stdlib amd64 3.12.7-3 [1966 kB] Get: 20 http://deb.debian.org/debian unstable/main amd64 python3.12 amd64 3.12.7-3 [671 kB] Get: 21 http://deb.debian.org/debian unstable/main amd64 libpython3-stdlib amd64 3.12.7-1 [9712 B] Get: 22 http://deb.debian.org/debian unstable/main amd64 python3 amd64 3.12.7-1 [27.8 kB] Get: 23 http://deb.debian.org/debian unstable/main amd64 libpython3.13-minimal amd64 3.13.0-2 [856 kB] Get: 24 http://deb.debian.org/debian unstable/main amd64 python3.13-minimal amd64 3.13.0-2 [2038 kB] Get: 25 http://deb.debian.org/debian unstable/main amd64 sensible-utils all 0.0.24 [24.8 kB] Get: 26 http://deb.debian.org/debian unstable/main amd64 libmagic-mgc amd64 1:5.45-3+b1 [314 kB] Get: 27 http://deb.debian.org/debian unstable/main amd64 libmagic1t64 amd64 1:5.45-3+b1 [108 kB] Get: 28 http://deb.debian.org/debian unstable/main amd64 file amd64 1:5.45-3+b1 [43.3 kB] Get: 29 http://deb.debian.org/debian unstable/main amd64 gettext-base amd64 0.22.5-2 [200 kB] Get: 30 http://deb.debian.org/debian unstable/main amd64 libuchardet0 amd64 0.0.8-1+b2 [68.9 kB] Get: 31 http://deb.debian.org/debian unstable/main amd64 groff-base amd64 1.23.0-5 [1181 kB] Get: 32 http://deb.debian.org/debian unstable/main amd64 bsdextrautils amd64 2.40.2-11 [91.5 kB] Get: 33 http://deb.debian.org/debian unstable/main amd64 libpipeline1 amd64 1.5.8-1 [42.0 kB] Get: 34 http://deb.debian.org/debian unstable/main amd64 man-db amd64 2.13.0-1 [1420 kB] Get: 35 http://deb.debian.org/debian unstable/main amd64 libantlr4-runtime4.9 amd64 4.9+dfsg-3+b2 [355 kB] Get: 36 http://deb.debian.org/debian unstable/main amd64 libicu72 amd64 72.1-5+b1 [9423 kB] Get: 37 http://deb.debian.org/debian unstable/main amd64 libxml2 amd64 2.12.7+dfsg+really2.9.14-0.2+b1 [699 kB] Get: 38 http://deb.debian.org/debian unstable/main amd64 afdko-bin amd64 4.0.1+dfsg1-2 [1137 kB] Get: 39 http://deb.debian.org/debian unstable/main amd64 m4 amd64 1.4.19-4 [287 kB] Get: 40 http://deb.debian.org/debian unstable/main amd64 autoconf all 2.72-3 [493 kB] Get: 41 http://deb.debian.org/debian unstable/main amd64 autotools-dev all 20220109.1 [51.6 kB] Get: 42 http://deb.debian.org/debian unstable/main amd64 automake all 1:1.16.5-1.3 [823 kB] Get: 43 http://deb.debian.org/debian unstable/main amd64 autopoint all 0.22.5-2 [723 kB] Get: 44 http://deb.debian.org/debian unstable/main amd64 libdebhelper-perl all 13.20 [89.7 kB] Get: 45 http://deb.debian.org/debian unstable/main amd64 libtool all 2.4.7-8 [517 kB] Get: 46 http://deb.debian.org/debian unstable/main amd64 dh-autoreconf all 20 [17.1 kB] Get: 47 http://deb.debian.org/debian unstable/main amd64 libarchive-zip-perl all 1.68-1 [104 kB] Get: 48 http://deb.debian.org/debian unstable/main amd64 libfile-stripnondeterminism-perl all 1.14.0-1 [19.5 kB] Get: 49 http://deb.debian.org/debian unstable/main amd64 dh-strip-nondeterminism all 1.14.0-1 [8448 B] Get: 50 http://deb.debian.org/debian unstable/main amd64 libelf1t64 amd64 0.192-4 [189 kB] Get: 51 http://deb.debian.org/debian unstable/main amd64 dwz amd64 0.15-1+b1 [110 kB] Get: 52 http://deb.debian.org/debian unstable/main amd64 gettext amd64 0.22.5-2 [1601 kB] Get: 53 http://deb.debian.org/debian unstable/main amd64 intltool-debian all 0.35.0+20060710.6 [22.9 kB] Get: 54 http://deb.debian.org/debian unstable/main amd64 po-debconf all 1.0.21+nmu1 [248 kB] Get: 55 http://deb.debian.org/debian unstable/main amd64 debhelper all 13.20 [915 kB] Get: 56 http://deb.debian.org/debian unstable/main amd64 python3-autocommand all 2.2.2-3 [13.6 kB] Get: 57 http://deb.debian.org/debian unstable/main amd64 python3-more-itertools all 10.5.0-1 [63.8 kB] Get: 58 http://deb.debian.org/debian unstable/main amd64 python3-typing-extensions all 4.12.2-2 [73.0 kB] Get: 59 http://deb.debian.org/debian unstable/main amd64 python3-typeguard all 4.4.1-1 [37.0 kB] Get: 60 http://deb.debian.org/debian unstable/main amd64 python3-inflect all 7.3.1-2 [32.4 kB] Get: 61 http://deb.debian.org/debian unstable/main amd64 python3-jaraco.context all 6.0.0-1 [7984 B] Get: 62 http://deb.debian.org/debian unstable/main amd64 python3-jaraco.functools all 4.1.0-1 [12.0 kB] Get: 63 http://deb.debian.org/debian unstable/main amd64 python3-pkg-resources all 75.2.0-1 [213 kB] Get: 64 http://deb.debian.org/debian unstable/main amd64 python3-jaraco.text all 4.0.0-1 [11.4 kB] Get: 65 http://deb.debian.org/debian unstable/main amd64 python3-zipp all 3.21.0-1 [10.6 kB] Get: 66 http://deb.debian.org/debian unstable/main amd64 python3-setuptools all 75.2.0-1 [731 kB] Get: 67 http://deb.debian.org/debian unstable/main amd64 dh-python all 6.20241024 [109 kB] Get: 68 http://deb.debian.org/debian unstable/main amd64 libblas3 amd64 3.12.0-4 [152 kB] Get: 69 http://deb.debian.org/debian unstable/main amd64 libgfortran5 amd64 14.2.0-8 [836 kB] Get: 70 http://deb.debian.org/debian unstable/main amd64 libjs-jquery all 3.6.1+dfsg+~3.5.14-1 [326 kB] Get: 71 http://deb.debian.org/debian unstable/main amd64 libjs-underscore all 1.13.4~dfsg+~1.11.4-3 [116 kB] Get: 72 http://deb.debian.org/debian unstable/main amd64 libjs-sphinxdoc all 7.4.7-4 [158 kB] Get: 73 http://deb.debian.org/debian unstable/main amd64 liblapack3 amd64 3.12.0-4 [2450 kB] Get: 74 http://deb.debian.org/debian unstable/main amd64 liblbfgsb0 amd64 3.0+dfsg.4-1+b2 [29.4 kB] Get: 75 http://deb.debian.org/debian unstable/main amd64 libpython3.13-stdlib amd64 3.13.0-2 [1992 kB] Get: 76 http://deb.debian.org/debian unstable/main amd64 libxslt1.1 amd64 1.1.35-1.1+b1 [233 kB] Get: 77 http://deb.debian.org/debian unstable/main amd64 python3.13 amd64 3.13.0-2 [730 kB] Get: 78 http://deb.debian.org/debian unstable/main amd64 python3-all amd64 3.12.7-1 [1052 B] Get: 79 http://deb.debian.org/debian unstable/main amd64 python3-appdirs all 1.4.4-4 [12.5 kB] Get: 80 http://deb.debian.org/debian unstable/main amd64 python3-attr all 24.2.0-1 [68.4 kB] Get: 81 http://deb.debian.org/debian unstable/main amd64 python3-brotli amd64 1.1.0-2+b6 [321 kB] Get: 82 http://deb.debian.org/debian unstable/main amd64 python3-tz all 2024.1-2 [30.9 kB] Get: 83 http://deb.debian.org/debian unstable/main amd64 python3-six all 1.16.0-7 [16.4 kB] Get: 84 http://deb.debian.org/debian unstable/main amd64 python3-fs all 2.4.16-4 [95.4 kB] Get: 85 http://deb.debian.org/debian unstable/main amd64 python3-lxml amd64 5.3.0-1+b1 [1676 kB] Get: 86 http://deb.debian.org/debian unstable/main amd64 python3-lz4 amd64 4.0.2+dfsg-1+b5 [25.6 kB] Get: 87 http://deb.debian.org/debian unstable/main amd64 python3-decorator all 5.1.1-5 [15.1 kB] Get: 88 http://deb.debian.org/debian unstable/main amd64 python3-numpy amd64 1:1.26.4+ds-12 [4738 kB] Get: 89 http://deb.debian.org/debian unstable/main amd64 python3-scipy amd64 1.14.1-2 [20.5 MB] Get: 90 http://deb.debian.org/debian unstable/main amd64 python3-mpmath all 1.3.0-1 [419 kB] Get: 91 http://deb.debian.org/debian unstable/main amd64 python3-sympy all 1.13.3-1 [4147 kB] Get: 92 http://deb.debian.org/debian unstable/main amd64 python3-ufolib2 all 0.16.1+dfsg1-1 [32.9 kB] Get: 93 http://deb.debian.org/debian unstable/main amd64 python3-defcon all 0.10.3-3 [189 kB] Get: 94 http://deb.debian.org/debian unstable/main amd64 unicode-data all 15.1.0-1 [8547 kB] Get: 95 http://deb.debian.org/debian unstable/main amd64 python3-fonttools amd64 4.55.0-3 [1634 kB] Get: 96 http://deb.debian.org/debian unstable/main amd64 python3-pyclipper amd64 1.3.0.post6-1+b1 [144 kB] Get: 97 http://deb.debian.org/debian unstable/main amd64 python3-booleanoperations all 0.9.0-3 [18.3 kB] Get: 98 http://deb.debian.org/debian unstable/main amd64 python3-cffsubr all 0.3.0-1 [9400 B] Get: 99 http://deb.debian.org/debian unstable/main amd64 python3-compreffor amd64 0.5.6-1+b1 [71.9 kB] Get: 100 http://deb.debian.org/debian unstable/main amd64 python3-fontmath all 0.9.4-1 [25.9 kB] Get: 101 http://deb.debian.org/debian unstable/main amd64 python3-iniconfig all 1.1.1-2 [6396 B] Get: 102 http://deb.debian.org/debian unstable/main amd64 python3-packaging all 24.2-1 [55.3 kB] Get: 103 http://deb.debian.org/debian unstable/main amd64 python3-pluggy all 1.5.0-1 [26.9 kB] Get: 104 http://deb.debian.org/debian unstable/main amd64 python3-pytest all 8.3.3-1 [249 kB] Get: 105 http://deb.debian.org/debian unstable/main amd64 python3-setuptools-scm all 8.1.0-1 [40.5 kB] Get: 106 http://deb.debian.org/debian unstable/main amd64 python3-syrupy all 4.7.2-1 [53.0 kB] Fetched 82.8 MB in 19s (4337 kB/s) debconf: delaying package configuration, since apt-utils is not installed Selecting previously unselected package libpython3.12-minimal:amd64. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 19966 files and directories currently installed.) Preparing to unpack .../libpython3.12-minimal_3.12.7-3_amd64.deb ... Unpacking libpython3.12-minimal:amd64 (3.12.7-3) ... Selecting previously unselected package libexpat1:amd64. Preparing to unpack .../libexpat1_2.6.4-1_amd64.deb ... Unpacking libexpat1:amd64 (2.6.4-1) ... Selecting previously unselected package python3.12-minimal. Preparing to unpack .../python3.12-minimal_3.12.7-3_amd64.deb ... Unpacking python3.12-minimal (3.12.7-3) ... Setting up libpython3.12-minimal:amd64 (3.12.7-3) ... Setting up libexpat1:amd64 (2.6.4-1) ... Setting up python3.12-minimal (3.12.7-3) ... Selecting previously unselected package python3-minimal. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 20286 files and directories currently installed.) Preparing to unpack .../00-python3-minimal_3.12.7-1_amd64.deb ... Unpacking python3-minimal (3.12.7-1) ... Selecting previously unselected package media-types. Preparing to unpack .../01-media-types_10.1.0_all.deb ... Unpacking media-types (10.1.0) ... Selecting previously unselected package netbase. Preparing to unpack .../02-netbase_6.4_all.deb ... Unpacking netbase (6.4) ... Selecting previously unselected package tzdata. Preparing to unpack .../03-tzdata_2024b-3_all.deb ... Unpacking tzdata (2024b-3) ... Selecting previously unselected package libkrb5support0:amd64. Preparing to unpack .../04-libkrb5support0_1.21.3-3_amd64.deb ... Unpacking libkrb5support0:amd64 (1.21.3-3) ... Selecting previously unselected package libcom-err2:amd64. Preparing to unpack .../05-libcom-err2_1.47.1-1+b1_amd64.deb ... Unpacking libcom-err2:amd64 (1.47.1-1+b1) ... Selecting previously unselected package libk5crypto3:amd64. Preparing to unpack .../06-libk5crypto3_1.21.3-3_amd64.deb ... Unpacking libk5crypto3:amd64 (1.21.3-3) ... Selecting previously unselected package libkeyutils1:amd64. Preparing to unpack .../07-libkeyutils1_1.6.3-4_amd64.deb ... Unpacking libkeyutils1:amd64 (1.6.3-4) ... Selecting previously unselected package libkrb5-3:amd64. Preparing to unpack .../08-libkrb5-3_1.21.3-3_amd64.deb ... Unpacking libkrb5-3:amd64 (1.21.3-3) ... Selecting previously unselected package libgssapi-krb5-2:amd64. Preparing to unpack .../09-libgssapi-krb5-2_1.21.3-3_amd64.deb ... Unpacking libgssapi-krb5-2:amd64 (1.21.3-3) ... Selecting previously unselected package libtirpc-common. Preparing to unpack .../10-libtirpc-common_1.3.4+ds-1.3_all.deb ... Unpacking libtirpc-common (1.3.4+ds-1.3) ... Selecting previously unselected package libtirpc3t64:amd64. Preparing to unpack .../11-libtirpc3t64_1.3.4+ds-1.3+b1_amd64.deb ... Adding 'diversion of /lib/x86_64-linux-gnu/libtirpc.so.3 to /lib/x86_64-linux-gnu/libtirpc.so.3.usr-is-merged by libtirpc3t64' Adding 'diversion of /lib/x86_64-linux-gnu/libtirpc.so.3.0.0 to /lib/x86_64-linux-gnu/libtirpc.so.3.0.0.usr-is-merged by libtirpc3t64' Unpacking libtirpc3t64:amd64 (1.3.4+ds-1.3+b1) ... Selecting previously unselected package libnsl2:amd64. Preparing to unpack .../12-libnsl2_1.3.0-3+b3_amd64.deb ... Unpacking libnsl2:amd64 (1.3.0-3+b3) ... Selecting previously unselected package readline-common. Preparing to unpack .../13-readline-common_8.2-5_all.deb ... Unpacking readline-common (8.2-5) ... Selecting previously unselected package libreadline8t64:amd64. Preparing to unpack .../14-libreadline8t64_8.2-5_amd64.deb ... Adding 'diversion of /lib/x86_64-linux-gnu/libhistory.so.8 to /lib/x86_64-linux-gnu/libhistory.so.8.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/x86_64-linux-gnu/libhistory.so.8.2 to /lib/x86_64-linux-gnu/libhistory.so.8.2.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/x86_64-linux-gnu/libreadline.so.8 to /lib/x86_64-linux-gnu/libreadline.so.8.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/x86_64-linux-gnu/libreadline.so.8.2 to /lib/x86_64-linux-gnu/libreadline.so.8.2.usr-is-merged by libreadline8t64' Unpacking libreadline8t64:amd64 (8.2-5) ... Selecting previously unselected package libpython3.12-stdlib:amd64. Preparing to unpack .../15-libpython3.12-stdlib_3.12.7-3_amd64.deb ... Unpacking libpython3.12-stdlib:amd64 (3.12.7-3) ... Selecting previously unselected package python3.12. Preparing to unpack .../16-python3.12_3.12.7-3_amd64.deb ... Unpacking python3.12 (3.12.7-3) ... Selecting previously unselected package libpython3-stdlib:amd64. Preparing to unpack .../17-libpython3-stdlib_3.12.7-1_amd64.deb ... Unpacking libpython3-stdlib:amd64 (3.12.7-1) ... Setting up python3-minimal (3.12.7-1) ... Selecting previously unselected package python3. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 21348 files and directories currently installed.) Preparing to unpack .../00-python3_3.12.7-1_amd64.deb ... Unpacking python3 (3.12.7-1) ... Selecting previously unselected package libpython3.13-minimal:amd64. Preparing to unpack .../01-libpython3.13-minimal_3.13.0-2_amd64.deb ... Unpacking libpython3.13-minimal:amd64 (3.13.0-2) ... Selecting previously unselected package python3.13-minimal. Preparing to unpack .../02-python3.13-minimal_3.13.0-2_amd64.deb ... Unpacking python3.13-minimal (3.13.0-2) ... Selecting previously unselected package sensible-utils. Preparing to unpack .../03-sensible-utils_0.0.24_all.deb ... Unpacking sensible-utils (0.0.24) ... Selecting previously unselected package libmagic-mgc. Preparing to unpack .../04-libmagic-mgc_1%3a5.45-3+b1_amd64.deb ... Unpacking libmagic-mgc (1:5.45-3+b1) ... Selecting previously unselected package libmagic1t64:amd64. Preparing to unpack .../05-libmagic1t64_1%3a5.45-3+b1_amd64.deb ... Unpacking libmagic1t64:amd64 (1:5.45-3+b1) ... Selecting previously unselected package file. Preparing to unpack .../06-file_1%3a5.45-3+b1_amd64.deb ... Unpacking file (1:5.45-3+b1) ... Selecting previously unselected package gettext-base. Preparing to unpack .../07-gettext-base_0.22.5-2_amd64.deb ... Unpacking gettext-base (0.22.5-2) ... Selecting previously unselected package libuchardet0:amd64. Preparing to unpack .../08-libuchardet0_0.0.8-1+b2_amd64.deb ... Unpacking libuchardet0:amd64 (0.0.8-1+b2) ... Selecting previously unselected package groff-base. Preparing to unpack .../09-groff-base_1.23.0-5_amd64.deb ... Unpacking groff-base (1.23.0-5) ... Selecting previously unselected package bsdextrautils. Preparing to unpack .../10-bsdextrautils_2.40.2-11_amd64.deb ... Unpacking bsdextrautils (2.40.2-11) ... Selecting previously unselected package libpipeline1:amd64. Preparing to unpack .../11-libpipeline1_1.5.8-1_amd64.deb ... Unpacking libpipeline1:amd64 (1.5.8-1) ... Selecting previously unselected package man-db. Preparing to unpack .../12-man-db_2.13.0-1_amd64.deb ... Unpacking man-db (2.13.0-1) ... Selecting previously unselected package libantlr4-runtime4.9:amd64. Preparing to unpack .../13-libantlr4-runtime4.9_4.9+dfsg-3+b2_amd64.deb ... Unpacking libantlr4-runtime4.9:amd64 (4.9+dfsg-3+b2) ... Selecting previously unselected package libicu72:amd64. Preparing to unpack .../14-libicu72_72.1-5+b1_amd64.deb ... Unpacking libicu72:amd64 (72.1-5+b1) ... Selecting previously unselected package libxml2:amd64. Preparing to unpack .../15-libxml2_2.12.7+dfsg+really2.9.14-0.2+b1_amd64.deb ... Unpacking libxml2:amd64 (2.12.7+dfsg+really2.9.14-0.2+b1) ... Selecting previously unselected package afdko-bin. Preparing to unpack .../16-afdko-bin_4.0.1+dfsg1-2_amd64.deb ... Unpacking afdko-bin (4.0.1+dfsg1-2) ... Selecting previously unselected package m4. Preparing to unpack .../17-m4_1.4.19-4_amd64.deb ... Unpacking m4 (1.4.19-4) ... Selecting previously unselected package autoconf. Preparing to unpack .../18-autoconf_2.72-3_all.deb ... Unpacking autoconf (2.72-3) ... Selecting previously unselected package autotools-dev. Preparing to unpack .../19-autotools-dev_20220109.1_all.deb ... Unpacking autotools-dev (20220109.1) ... Selecting previously unselected package automake. Preparing to unpack .../20-automake_1%3a1.16.5-1.3_all.deb ... Unpacking automake (1:1.16.5-1.3) ... Selecting previously unselected package autopoint. Preparing to unpack .../21-autopoint_0.22.5-2_all.deb ... Unpacking autopoint (0.22.5-2) ... Selecting previously unselected package libdebhelper-perl. Preparing to unpack .../22-libdebhelper-perl_13.20_all.deb ... Unpacking libdebhelper-perl (13.20) ... Selecting previously unselected package libtool. Preparing to unpack .../23-libtool_2.4.7-8_all.deb ... Unpacking libtool (2.4.7-8) ... Selecting previously unselected package dh-autoreconf. Preparing to unpack .../24-dh-autoreconf_20_all.deb ... Unpacking dh-autoreconf (20) ... Selecting previously unselected package libarchive-zip-perl. Preparing to unpack .../25-libarchive-zip-perl_1.68-1_all.deb ... Unpacking libarchive-zip-perl (1.68-1) ... Selecting previously unselected package libfile-stripnondeterminism-perl. Preparing to unpack .../26-libfile-stripnondeterminism-perl_1.14.0-1_all.deb ... Unpacking libfile-stripnondeterminism-perl (1.14.0-1) ... Selecting previously unselected package dh-strip-nondeterminism. Preparing to unpack .../27-dh-strip-nondeterminism_1.14.0-1_all.deb ... Unpacking dh-strip-nondeterminism (1.14.0-1) ... Selecting previously unselected package libelf1t64:amd64. Preparing to unpack .../28-libelf1t64_0.192-4_amd64.deb ... Unpacking libelf1t64:amd64 (0.192-4) ... Selecting previously unselected package dwz. Preparing to unpack .../29-dwz_0.15-1+b1_amd64.deb ... Unpacking dwz (0.15-1+b1) ... Selecting previously unselected package gettext. Preparing to unpack .../30-gettext_0.22.5-2_amd64.deb ... Unpacking gettext (0.22.5-2) ... Selecting previously unselected package intltool-debian. Preparing to unpack .../31-intltool-debian_0.35.0+20060710.6_all.deb ... Unpacking intltool-debian (0.35.0+20060710.6) ... Selecting previously unselected package po-debconf. Preparing to unpack .../32-po-debconf_1.0.21+nmu1_all.deb ... Unpacking po-debconf (1.0.21+nmu1) ... Selecting previously unselected package debhelper. Preparing to unpack .../33-debhelper_13.20_all.deb ... Unpacking debhelper (13.20) ... Selecting previously unselected package python3-autocommand. Preparing to unpack .../34-python3-autocommand_2.2.2-3_all.deb ... Unpacking python3-autocommand (2.2.2-3) ... Selecting previously unselected package python3-more-itertools. Preparing to unpack .../35-python3-more-itertools_10.5.0-1_all.deb ... Unpacking python3-more-itertools (10.5.0-1) ... Selecting previously unselected package python3-typing-extensions. Preparing to unpack .../36-python3-typing-extensions_4.12.2-2_all.deb ... Unpacking python3-typing-extensions (4.12.2-2) ... Selecting previously unselected package python3-typeguard. Preparing to unpack .../37-python3-typeguard_4.4.1-1_all.deb ... Unpacking python3-typeguard (4.4.1-1) ... Selecting previously unselected package python3-inflect. Preparing to unpack .../38-python3-inflect_7.3.1-2_all.deb ... Unpacking python3-inflect (7.3.1-2) ... Selecting previously unselected package python3-jaraco.context. Preparing to unpack .../39-python3-jaraco.context_6.0.0-1_all.deb ... Unpacking python3-jaraco.context (6.0.0-1) ... Selecting previously unselected package python3-jaraco.functools. Preparing to unpack .../40-python3-jaraco.functools_4.1.0-1_all.deb ... Unpacking python3-jaraco.functools (4.1.0-1) ... Selecting previously unselected package python3-pkg-resources. Preparing to unpack .../41-python3-pkg-resources_75.2.0-1_all.deb ... Unpacking python3-pkg-resources (75.2.0-1) ... Selecting previously unselected package python3-jaraco.text. Preparing to unpack .../42-python3-jaraco.text_4.0.0-1_all.deb ... Unpacking python3-jaraco.text (4.0.0-1) ... Selecting previously unselected package python3-zipp. Preparing to unpack .../43-python3-zipp_3.21.0-1_all.deb ... Unpacking python3-zipp (3.21.0-1) ... Selecting previously unselected package python3-setuptools. Preparing to unpack .../44-python3-setuptools_75.2.0-1_all.deb ... Unpacking python3-setuptools (75.2.0-1) ... Selecting previously unselected package dh-python. Preparing to unpack .../45-dh-python_6.20241024_all.deb ... Unpacking dh-python (6.20241024) ... Selecting previously unselected package libblas3:amd64. Preparing to unpack .../46-libblas3_3.12.0-4_amd64.deb ... Unpacking libblas3:amd64 (3.12.0-4) ... Selecting previously unselected package libgfortran5:amd64. Preparing to unpack .../47-libgfortran5_14.2.0-8_amd64.deb ... Unpacking libgfortran5:amd64 (14.2.0-8) ... Selecting previously unselected package libjs-jquery. Preparing to unpack .../48-libjs-jquery_3.6.1+dfsg+~3.5.14-1_all.deb ... Unpacking libjs-jquery (3.6.1+dfsg+~3.5.14-1) ... Selecting previously unselected package libjs-underscore. Preparing to unpack .../49-libjs-underscore_1.13.4~dfsg+~1.11.4-3_all.deb ... Unpacking libjs-underscore (1.13.4~dfsg+~1.11.4-3) ... Selecting previously unselected package libjs-sphinxdoc. Preparing to unpack .../50-libjs-sphinxdoc_7.4.7-4_all.deb ... Unpacking libjs-sphinxdoc (7.4.7-4) ... Selecting previously unselected package liblapack3:amd64. Preparing to unpack .../51-liblapack3_3.12.0-4_amd64.deb ... Unpacking liblapack3:amd64 (3.12.0-4) ... Selecting previously unselected package liblbfgsb0:amd64. Preparing to unpack .../52-liblbfgsb0_3.0+dfsg.4-1+b2_amd64.deb ... Unpacking liblbfgsb0:amd64 (3.0+dfsg.4-1+b2) ... Selecting previously unselected package libpython3.13-stdlib:amd64. Preparing to unpack .../53-libpython3.13-stdlib_3.13.0-2_amd64.deb ... Unpacking libpython3.13-stdlib:amd64 (3.13.0-2) ... Selecting previously unselected package libxslt1.1:amd64. Preparing to unpack .../54-libxslt1.1_1.1.35-1.1+b1_amd64.deb ... Unpacking libxslt1.1:amd64 (1.1.35-1.1+b1) ... Selecting previously unselected package python3.13. Preparing to unpack .../55-python3.13_3.13.0-2_amd64.deb ... Unpacking python3.13 (3.13.0-2) ... Selecting previously unselected package python3-all. Preparing to unpack .../56-python3-all_3.12.7-1_amd64.deb ... Unpacking python3-all (3.12.7-1) ... Selecting previously unselected package python3-appdirs. Preparing to unpack .../57-python3-appdirs_1.4.4-4_all.deb ... Unpacking python3-appdirs (1.4.4-4) ... Selecting previously unselected package python3-attr. Preparing to unpack .../58-python3-attr_24.2.0-1_all.deb ... Unpacking python3-attr (24.2.0-1) ... Selecting previously unselected package python3-brotli. Preparing to unpack .../59-python3-brotli_1.1.0-2+b6_amd64.deb ... Unpacking python3-brotli (1.1.0-2+b6) ... Selecting previously unselected package python3-tz. Preparing to unpack .../60-python3-tz_2024.1-2_all.deb ... Unpacking python3-tz (2024.1-2) ... Selecting previously unselected package python3-six. Preparing to unpack .../61-python3-six_1.16.0-7_all.deb ... Unpacking python3-six (1.16.0-7) ... Selecting previously unselected package python3-fs. Preparing to unpack .../62-python3-fs_2.4.16-4_all.deb ... Unpacking python3-fs (2.4.16-4) ... Selecting previously unselected package python3-lxml:amd64. Preparing to unpack .../63-python3-lxml_5.3.0-1+b1_amd64.deb ... Unpacking python3-lxml:amd64 (5.3.0-1+b1) ... Selecting previously unselected package python3-lz4. Preparing to unpack .../64-python3-lz4_4.0.2+dfsg-1+b5_amd64.deb ... Unpacking python3-lz4 (4.0.2+dfsg-1+b5) ... Selecting previously unselected package python3-decorator. Preparing to unpack .../65-python3-decorator_5.1.1-5_all.deb ... Unpacking python3-decorator (5.1.1-5) ... Selecting previously unselected package python3-numpy. Preparing to unpack .../66-python3-numpy_1%3a1.26.4+ds-12_amd64.deb ... Unpacking python3-numpy (1:1.26.4+ds-12) ... Selecting previously unselected package python3-scipy. Preparing to unpack .../67-python3-scipy_1.14.1-2_amd64.deb ... Unpacking python3-scipy (1.14.1-2) ... Selecting previously unselected package python3-mpmath. Preparing to unpack .../68-python3-mpmath_1.3.0-1_all.deb ... Unpacking python3-mpmath (1.3.0-1) ... Selecting previously unselected package python3-sympy. Preparing to unpack .../69-python3-sympy_1.13.3-1_all.deb ... Unpacking python3-sympy (1.13.3-1) ... Selecting previously unselected package python3-ufolib2. Preparing to unpack .../70-python3-ufolib2_0.16.1+dfsg1-1_all.deb ... Unpacking python3-ufolib2 (0.16.1+dfsg1-1) ... Selecting previously unselected package python3-defcon. Preparing to unpack .../71-python3-defcon_0.10.3-3_all.deb ... Unpacking python3-defcon (0.10.3-3) ... Selecting previously unselected package unicode-data. Preparing to unpack .../72-unicode-data_15.1.0-1_all.deb ... Unpacking unicode-data (15.1.0-1) ... Selecting previously unselected package python3-fonttools. Preparing to unpack .../73-python3-fonttools_4.55.0-3_amd64.deb ... Unpacking python3-fonttools (4.55.0-3) ... Selecting previously unselected package python3-pyclipper. Preparing to unpack .../74-python3-pyclipper_1.3.0.post6-1+b1_amd64.deb ... Unpacking python3-pyclipper (1.3.0.post6-1+b1) ... Selecting previously unselected package python3-booleanoperations. Preparing to unpack .../75-python3-booleanoperations_0.9.0-3_all.deb ... Unpacking python3-booleanoperations (0.9.0-3) ... Selecting previously unselected package python3-cffsubr. Preparing to unpack .../76-python3-cffsubr_0.3.0-1_all.deb ... Unpacking python3-cffsubr (0.3.0-1) ... Selecting previously unselected package python3-compreffor. Preparing to unpack .../77-python3-compreffor_0.5.6-1+b1_amd64.deb ... Unpacking python3-compreffor (0.5.6-1+b1) ... Selecting previously unselected package python3-fontmath. Preparing to unpack .../78-python3-fontmath_0.9.4-1_all.deb ... Unpacking python3-fontmath (0.9.4-1) ... Selecting previously unselected package python3-iniconfig. Preparing to unpack .../79-python3-iniconfig_1.1.1-2_all.deb ... Unpacking python3-iniconfig (1.1.1-2) ... Selecting previously unselected package python3-packaging. Preparing to unpack .../80-python3-packaging_24.2-1_all.deb ... Unpacking python3-packaging (24.2-1) ... Selecting previously unselected package python3-pluggy. Preparing to unpack .../81-python3-pluggy_1.5.0-1_all.deb ... Unpacking python3-pluggy (1.5.0-1) ... Selecting previously unselected package python3-pytest. Preparing to unpack .../82-python3-pytest_8.3.3-1_all.deb ... Unpacking python3-pytest (8.3.3-1) ... Selecting previously unselected package python3-setuptools-scm. Preparing to unpack .../83-python3-setuptools-scm_8.1.0-1_all.deb ... Unpacking python3-setuptools-scm (8.1.0-1) ... Selecting previously unselected package python3-syrupy. Preparing to unpack .../84-python3-syrupy_4.7.2-1_all.deb ... Unpacking python3-syrupy (4.7.2-1) ... Setting up media-types (10.1.0) ... Setting up libpipeline1:amd64 (1.5.8-1) ... Setting up libkeyutils1:amd64 (1.6.3-4) ... Setting up libicu72:amd64 (72.1-5+b1) ... Setting up bsdextrautils (2.40.2-11) ... Setting up libmagic-mgc (1:5.45-3+b1) ... Setting up libantlr4-runtime4.9:amd64 (4.9+dfsg-3+b2) ... Setting up libarchive-zip-perl (1.68-1) ... Setting up libtirpc-common (1.3.4+ds-1.3) ... Setting up libdebhelper-perl (13.20) ... Setting up libmagic1t64:amd64 (1:5.45-3+b1) ... Setting up gettext-base (0.22.5-2) ... Setting up m4 (1.4.19-4) ... Setting up libcom-err2:amd64 (1.47.1-1+b1) ... Setting up file (1:5.45-3+b1) ... Setting up libelf1t64:amd64 (0.192-4) ... Setting up libkrb5support0:amd64 (1.21.3-3) ... Setting up tzdata (2024b-3) ... Current default time zone: 'Etc/UTC' Local time is now: Sun Nov 24 19:25:46 UTC 2024. Universal Time is now: Sun Nov 24 19:25:46 UTC 2024. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up unicode-data (15.1.0-1) ... Setting up libpython3.13-minimal:amd64 (3.13.0-2) ... Setting up autotools-dev (20220109.1) ... Setting up libblas3:amd64 (3.12.0-4) ... update-alternatives: using /usr/lib/x86_64-linux-gnu/blas/libblas.so.3 to provide /usr/lib/x86_64-linux-gnu/libblas.so.3 (libblas.so.3-x86_64-linux-gnu) in auto mode Setting up autopoint (0.22.5-2) ... Setting up libk5crypto3:amd64 (1.21.3-3) ... Setting up libgfortran5:amd64 (14.2.0-8) ... Setting up autoconf (2.72-3) ... Setting up dwz (0.15-1+b1) ... Setting up sensible-utils (0.0.24) ... Setting up libuchardet0:amd64 (0.0.8-1+b2) ... Setting up python3.13-minimal (3.13.0-2) ... Setting up netbase (6.4) ... Setting up libkrb5-3:amd64 (1.21.3-3) ... Setting up libjs-jquery (3.6.1+dfsg+~3.5.14-1) ... Setting up readline-common (8.2-5) ... Setting up libxml2:amd64 (2.12.7+dfsg+really2.9.14-0.2+b1) ... Setting up libjs-underscore (1.13.4~dfsg+~1.11.4-3) ... Setting up automake (1:1.16.5-1.3) ... update-alternatives: using /usr/bin/automake-1.16 to provide /usr/bin/automake (automake) in auto mode Setting up libfile-stripnondeterminism-perl (1.14.0-1) ... Setting up liblapack3:amd64 (3.12.0-4) ... update-alternatives: using /usr/lib/x86_64-linux-gnu/lapack/liblapack.so.3 to provide /usr/lib/x86_64-linux-gnu/liblapack.so.3 (liblapack.so.3-x86_64-linux-gnu) in auto mode Setting up gettext (0.22.5-2) ... Setting up libtool (2.4.7-8) ... Setting up intltool-debian (0.35.0+20060710.6) ... Setting up dh-autoreconf (20) ... Setting up libgssapi-krb5-2:amd64 (1.21.3-3) ... Setting up libjs-sphinxdoc (7.4.7-4) ... Setting up libreadline8t64:amd64 (8.2-5) ... Setting up dh-strip-nondeterminism (1.14.0-1) ... Setting up groff-base (1.23.0-5) ... Setting up libxslt1.1:amd64 (1.1.35-1.1+b1) ... Setting up afdko-bin (4.0.1+dfsg1-2) ... Setting up libpython3.13-stdlib:amd64 (3.13.0-2) ... Setting up liblbfgsb0:amd64 (3.0+dfsg.4-1+b2) ... Setting up libtirpc3t64:amd64 (1.3.4+ds-1.3+b1) ... Setting up python3.13 (3.13.0-2) ... Setting up po-debconf (1.0.21+nmu1) ... Setting up man-db (2.13.0-1) ... Not building database; man-db/auto-update is not 'true'. Setting up libnsl2:amd64 (1.3.0-3+b3) ... Setting up libpython3.12-stdlib:amd64 (3.12.7-3) ... Setting up python3.12 (3.12.7-3) ... Setting up debhelper (13.20) ... Setting up libpython3-stdlib:amd64 (3.12.7-1) ... Setting up python3 (3.12.7-1) ... Setting up python3-zipp (3.21.0-1) ... Setting up python3-autocommand (2.2.2-3) ... Setting up python3-tz (2024.1-2) ... Setting up python3-six (1.16.0-7) ... Setting up python3-decorator (5.1.1-5) ... Setting up python3-packaging (24.2-1) ... Setting up python3-brotli (1.1.0-2+b6) ... Setting up python3-typing-extensions (4.12.2-2) ... Setting up python3-pluggy (1.5.0-1) ... Setting up python3-lxml:amd64 (5.3.0-1+b1) ... Setting up python3-mpmath (1.3.0-1) ... Setting up python3-appdirs (1.4.4-4) ... Setting up python3-pyclipper (1.3.0.post6-1+b1) ... Setting up python3-more-itertools (10.5.0-1) ... Setting up python3-iniconfig (1.1.1-2) ... Setting up python3-sympy (1.13.3-1) ... Setting up python3-attr (24.2.0-1) ... Setting up python3-jaraco.functools (4.1.0-1) ... Setting up python3-jaraco.context (6.0.0-1) ... Setting up python3-lz4 (4.0.2+dfsg-1+b5) ... Setting up python3-pytest (8.3.3-1) ... Setting up python3-syrupy (4.7.2-1) ... Setting up python3-typeguard (4.4.1-1) ... Setting up python3-all (3.12.7-1) ... Setting up python3-inflect (7.3.1-2) ... Setting up python3-jaraco.text (4.0.0-1) ... Setting up python3-pkg-resources (75.2.0-1) ... Setting up python3-setuptools (75.2.0-1) ... Setting up python3-setuptools-scm (8.1.0-1) ... Setting up python3-fs (2.4.16-4) ... Setting up python3-numpy (1:1.26.4+ds-12) ... Setting up dh-python (6.20241024) ... Setting up python3-scipy (1.14.1-2) ... Setting up python3-defcon (0.10.3-3) ... Setting up python3-fonttools (4.55.0-3) ... Setting up python3-ufolib2 (0.16.1+dfsg1-1) ... Setting up python3-fontmath (0.9.4-1) ... Setting up python3-cffsubr (0.3.0-1) ... Setting up python3-booleanoperations (0.9.0-3) ... Setting up python3-compreffor (0.5.6-1+b1) ... Processing triggers for libc-bin (2.40-4) ... Reading package lists... Building dependency tree... Reading state information... Reading extended state information... Initializing package states... Writing extended state information... Building tag database... -> Finished parsing the build-deps Reading package lists... Building dependency tree... Reading state information... fakeroot is already the newest version (1.36-1). 0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. I: Building the package I: Running cd /build/reproducible-path/ufo2ft-3.3.1/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-genchanges -S > ../ufo2ft_3.3.1-2_source.changes dpkg-buildpackage: info: source package ufo2ft dpkg-buildpackage: info: source version 3.3.1-2 dpkg-buildpackage: info: source distribution unstable dpkg-buildpackage: info: source changed by Boyuan Yang dpkg-source --before-build . dpkg-buildpackage: info: host architecture amd64 fakeroot debian/rules clean dh clean --buildsystem=pybuild debian/rules override_dh_auto_clean make[1]: Entering directory '/build/reproducible-path/ufo2ft-3.3.1' dh_auto_clean I: pybuild base:311: python3.13 setup.py clean /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running clean removing '/build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build' (and everything under it) 'build/bdist.linux-x86_64' does not exist -- can't clean it 'build/scripts-3.13' does not exist -- can't clean it I: pybuild base:311: python3.12 setup.py clean /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running clean removing '/build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build' (and everything under it) 'build/bdist.linux-x86_64' does not exist -- can't clean it 'build/scripts-3.12' does not exist -- can't clean it rm Lib/ufo2ft/_version.py make[1]: Leaving directory '/build/reproducible-path/ufo2ft-3.3.1' dh_autoreconf_clean -O--buildsystem=pybuild dh_clean -O--buildsystem=pybuild debian/rules build dh build --buildsystem=pybuild dh_update_autotools_config -O--buildsystem=pybuild dh_autoreconf -O--buildsystem=pybuild dh_auto_configure -O--buildsystem=pybuild I: pybuild base:311: python3.13 setup.py config /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running config I: pybuild base:311: python3.12 setup.py config /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running config dh_auto_build -O--buildsystem=pybuild I: pybuild base:311: /usr/bin/python3.13 setup.py build /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running build running build_py creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters running egg_info creating Lib/ufo2ft.egg-info writing Lib/ufo2ft.egg-info/PKG-INFO writing dependency_links to Lib/ufo2ft.egg-info/dependency_links.txt writing requirements to Lib/ufo2ft.egg-info/requires.txt writing top-level names to Lib/ufo2ft.egg-info/top_level.txt writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' adding license file 'LICENSE' writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' I: pybuild base:311: /usr/bin/python3 setup.py build /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running build running build_py creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters running egg_info writing Lib/ufo2ft.egg-info/PKG-INFO writing dependency_links to Lib/ufo2ft.egg-info/dependency_links.txt writing requirements to Lib/ufo2ft.egg-info/requires.txt writing top-level names to Lib/ufo2ft.egg-info/top_level.txt reading manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' adding license file 'LICENSE' writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' debian/rules override_dh_auto_test make[1]: Entering directory '/build/reproducible-path/ufo2ft-3.3.1' # For experimental build, allow failures dh_auto_test I: pybuild base:311: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build; python3.13 -m pytest tests ============================= test session starts ============================== platform linux -- Python 3.13.0, pytest-8.3.3, pluggy-1.5.0 rootdir: /build/reproducible-path/ufo2ft-3.3.1 configfile: setup.cfg plugins: syrupy-4.7.2, typeguard-4.4.1 collected 1140 items tests/featureCompiler_test.py ................ [ 1%] tests/featureWriters/cursFeatureWriter_test.py ......... [ 2%] tests/featureWriters/featureWriters_test.py ........ [ 2%] tests/featureWriters/gdefFeatureWriter_test.py .......... [ 3%] tests/featureWriters/kernFeatureWriter2_test.py ........................ [ 5%] ....F..... [ 6%] tests/featureWriters/kernFeatureWriter_test.py ......................... [ 8%] ......F..... [ 10%] tests/featureWriters/markFeatureWriter_test.py ......................... [ 12%] ............ [ 13%] tests/featureWriters/variableFeatureWriter_test.py .. [ 13%] tests/filters/decomposeComponents_test.py ...... [ 13%] tests/filters/decomposeTransformedComponents_test.py ... [ 14%] tests/filters/dottedCircle_test.py ... [ 14%] tests/filters/explodeColorLayerGlyphs_test.py . [ 14%] tests/filters/flattenComponents_test.py ........ [ 15%] tests/filters/propagateAnchors_test.py ............... [ 16%] tests/filters/sortContours_test.py .... [ 16%] tests/filters/transformations_test.py ............................... [ 19%] tests/fontInfoData_test.py ................ [ 21%] tests/infoCompiler_test.py ....... [ 21%] tests/instantiator_test.py ........................... [ 24%] tests/instructionCompiler_test.py ...................................... [ 27%] ......... [ 28%] tests/integration_test.py ......s.s.............FFFFFFF...FF.....FF..... [ 32%] ..............FF. [ 33%] tests/outlineCompiler_test.py .......................................... [ 37%] ........................................................................ [ 43%] ........................ [ 45%] tests/preProcessor_test.py ....s......s.............. [ 48%] tests/util_test.py . [ 48%] tests/featureCompiler_test.py ................ [ 49%] tests/featureWriters/cursFeatureWriter_test.py ......... [ 50%] tests/featureWriters/featureWriters_test.py ........ [ 51%] tests/featureWriters/gdefFeatureWriter_test.py .......... [ 51%] tests/featureWriters/kernFeatureWriter2_test.py ........................ [ 54%] ....F..... [ 54%] tests/featureWriters/kernFeatureWriter_test.py ......................... [ 57%] ......F..... [ 58%] tests/featureWriters/markFeatureWriter_test.py ......................... [ 60%] ............ [ 61%] tests/featureWriters/variableFeatureWriter_test.py .. [ 61%] tests/filters/decomposeComponents_test.py ...... [ 62%] tests/filters/decomposeTransformedComponents_test.py ... [ 62%] tests/filters/dottedCircle_test.py ... [ 62%] tests/filters/explodeColorLayerGlyphs_test.py . [ 62%] tests/filters/flattenComponents_test.py ........ [ 63%] tests/filters/propagateAnchors_test.py ............... [ 64%] tests/filters/sortContours_test.py .... [ 65%] tests/filters/transformations_test.py ............................... [ 67%] tests/fontInfoData_test.py ................ [ 69%] tests/infoCompiler_test.py ....... [ 69%] tests/instantiator_test.py ........................... [ 72%] tests/instructionCompiler_test.py ...................................... [ 75%] ......... [ 76%] tests/integration_test.py ......s.s.............FFFFFFF...FF.....FF..... [ 80%] ..............FF. [ 81%] tests/outlineCompiler_test.py .......................................... [ 85%] ........................................................................ [ 91%] ........................ [ 93%] tests/preProcessor_test.py ....s......s.............. [ 96%] tests/util_test.py . [ 96%] tests/featureWriters/ast_test.py . [ 96%] tests/featureWriters/markFeatureWriter_test.py ......... [ 97%] tests/filters/filters_test.py ................... [ 98%] tests/filters/transformations_test.py . [ 98%] tests/fontInfoData_test.py .. [ 99%] tests/instantiator_test.py .... [ 99%] tests/instructionCompiler_test.py .... [ 99%] tests/util_test.py .. [100%] =================================== FAILURES =================================== _________________________ test_kern_zyyy_zinh[defcon] __________________________ snapshot = ''' lookup kern_dflt { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni0310 uni0310 1; pos uni03...a; language dflt; lookup kern_dflt; script dupl; language dflt; lookup kern_dflt; } dist; ''' FontClass = def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert newFeatures.asFea() == snapshot E AssertionError: assert [+ received] == [- snapshot] E ''' E ... E lookupflag IgnoreMarks; E - pos uni0300 uni0300 0; E - pos uni0310 uni0310 1; E - pos uni0320 uni0320 2; E - pos uni0330 uni0330 3;... E E ...Full output truncated (85 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[defcon] __________________________ FontClass = def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert dedent(str(newFeatures)) == dedent( """\ lookup kern_Deva { lookupflag IgnoreMarks; pos uni1CD0 uni1CD0 7; pos uni1CE0 uni1CE0 8; pos uni1CF0 uni1CF0 9; pos uni20F0 uni20F0 11; pos uniA830 uniA830 34; } kern_Deva; lookup kern_Dupl { lookupflag IgnoreMarks; pos uni1BCA0 uni1BCA0 42; } kern_Dupl; lookup kern_Grek { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni1DC0 uni1DC0 10; } kern_Grek; lookup kern_Hani_Hrkt { lookupflag IgnoreMarks; pos uni1D360 uni1D360 43; pos uni1D370 uni1D370 44; pos uni1F250 uni1F250 45; pos uni2FF0 uni2FF0 13; pos uni3010 uni3010 14; pos uni3030 uni3030 15; pos uni30A0 uni30A0 16; pos uni3190 uni3190 17; pos uni31C0 uni31C0 18; pos uni31D0 uni31D0 19; pos uni31E0 uni31E0 20; pos uni3220 uni3220 21; pos uni3230 uni3230 22; pos uni3240 uni3240 23; pos uni3280 uni3280 24; pos uni3290 uni3290 25; pos uni32A0 uni32A0 26; pos uni32B0 uni32B0 27; pos uni32C0 uni32C0 28; pos uni3360 uni3360 29; pos uni3370 uni3370 30; pos uni33E0 uni33E0 31; pos uni33F0 uni33F0 32; pos uniA700 uniA700 33; pos uniFF70 uniFF70 35; } kern_Hani_Hrkt; lookup kern_Default { lookupflag IgnoreMarks; pos uni0310 uni0310 1; pos uni0320 uni0320 2; pos uni0330 uni0330 3; pos uni0640 uni0640 4; pos uni0650 uni0650 5; pos uni0670 uni0670 6; pos uni10100 uni10100 36; pos uni10110 uni10110 37; pos uni10120 uni10120 38; pos uni10130 uni10130 39; pos uni102E0 uni102E0 40; pos uni102F0 uni102F0 41; pos uni2E30 uni2E30 12; } kern_Default; feature kern { script DFLT; language dflt; lookup kern_Default; lookup kern_Grek; lookup kern_Hani_Hrkt; script grek; language dflt; lookup kern_Default; lookup kern_Grek; script hani; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; script kana; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; } kern; feature dist { script dev2; language dflt; lookup kern_Default; lookup kern_Deva; script deva; language dflt; lookup kern_Default; lookup kern_Deva; script dupl; language dflt; lookup kern_Default; lookup kern_Dupl; } dist; """ ) E AssertionError: assert 'lookup kern_...l;\n} dist;\n' == 'lookup kern_...l;\n} dist;\n' E E Skipping 61 identical leading characters in diff, use -v to show E - 0 uni1CD0 7; E ? ^ E + 0 uni1CD0 3; E ? ^ E - pos uni1CE0 uni1CE0 8;... E E ...Full output truncated (218 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError _____________ IntegrationTest.test_compileVariableTTF[defcon-None] _____________ self = designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _____________ IntegrationTest.test_compileVariableTTF[defcon-True] _____________ self = designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-useProductionNames.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[defcon-False] _____________ self = designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-None] _____________ self = designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-True] _____________ self = designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-useProductionNames.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-False] ____________ self = designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ________ IntegrationTest.test_compileVariableCFF2_subroutinized[defcon] ________ self = designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) > expectTTX(varfont, "TestVariableFont-CFF2-cffsubr.ttx") tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-cffsubr.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ self = designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-post3.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ self = designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-post3.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _______________ IntegrationTest.test_compileVariableTTFs[defcon] _______________ self = designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-TTF.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-TTF.ttx", ) tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-TTF.ttx +++ @@ -251,99 +251,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -417,42 +324,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -635,17 +539,17 @@ - + - + - + @@ -654,7 +558,7 @@ - + @@ -671,7 +575,7 @@ - + @@ -688,13 +592,13 @@ - + - + @@ -702,7 +606,7 @@ - + @@ -710,7 +614,7 @@ - + @@ -718,7 +622,7 @@ - + @@ -726,7 +630,7 @@ - + @@ -734,13 +638,13 @@ - + - + ______________ IntegrationTest.test_compileVariableCFF2s[defcon] _______________ self = designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-CFF2.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx", ) tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx +++ @@ -128,99 +128,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -294,42 +201,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -692,17 +596,17 @@ - + - + - + @@ -711,7 +615,7 @@ - + @@ -728,7 +632,7 @@ - + @@ -745,13 +649,13 @@ - + - + @@ -759,7 +663,7 @@ - + @@ -767,7 +671,7 @@ - + @@ -775,7 +679,7 @@ - + @@ -783,7 +687,7 @@ - + @@ -791,13 +695,13 @@ - + - + _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableTTFs] ______ self = FontClass = compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableCFF2s] _____ self = FontClass = compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ snapshot = ''' lookup kern_dflt { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni0310 uni0310 1; pos uni03...a; language dflt; lookup kern_dflt; script dupl; language dflt; lookup kern_dflt; } dist; ''' FontClass = .ctor at 0x7f2cd9daade0> def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert newFeatures.asFea() == snapshot E AssertionError: assert [+ received] == [- snapshot] E ''' E ... E lookupflag IgnoreMarks; E - pos uni0300 uni0300 0; E - pos uni0310 uni0310 1; E - pos uni0320 uni0320 2; E - pos uni0330 uni0330 3;... E E ...Full output truncated (85 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ FontClass = .ctor at 0x7f2cd9daade0> def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert dedent(str(newFeatures)) == dedent( """\ lookup kern_Deva { lookupflag IgnoreMarks; pos uni1CD0 uni1CD0 7; pos uni1CE0 uni1CE0 8; pos uni1CF0 uni1CF0 9; pos uni20F0 uni20F0 11; pos uniA830 uniA830 34; } kern_Deva; lookup kern_Dupl { lookupflag IgnoreMarks; pos uni1BCA0 uni1BCA0 42; } kern_Dupl; lookup kern_Grek { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni1DC0 uni1DC0 10; } kern_Grek; lookup kern_Hani_Hrkt { lookupflag IgnoreMarks; pos uni1D360 uni1D360 43; pos uni1D370 uni1D370 44; pos uni1F250 uni1F250 45; pos uni2FF0 uni2FF0 13; pos uni3010 uni3010 14; pos uni3030 uni3030 15; pos uni30A0 uni30A0 16; pos uni3190 uni3190 17; pos uni31C0 uni31C0 18; pos uni31D0 uni31D0 19; pos uni31E0 uni31E0 20; pos uni3220 uni3220 21; pos uni3230 uni3230 22; pos uni3240 uni3240 23; pos uni3280 uni3280 24; pos uni3290 uni3290 25; pos uni32A0 uni32A0 26; pos uni32B0 uni32B0 27; pos uni32C0 uni32C0 28; pos uni3360 uni3360 29; pos uni3370 uni3370 30; pos uni33E0 uni33E0 31; pos uni33F0 uni33F0 32; pos uniA700 uniA700 33; pos uniFF70 uniFF70 35; } kern_Hani_Hrkt; lookup kern_Default { lookupflag IgnoreMarks; pos uni0310 uni0310 1; pos uni0320 uni0320 2; pos uni0330 uni0330 3; pos uni0640 uni0640 4; pos uni0650 uni0650 5; pos uni0670 uni0670 6; pos uni10100 uni10100 36; pos uni10110 uni10110 37; pos uni10120 uni10120 38; pos uni10130 uni10130 39; pos uni102E0 uni102E0 40; pos uni102F0 uni102F0 41; pos uni2E30 uni2E30 12; } kern_Default; feature kern { script DFLT; language dflt; lookup kern_Default; lookup kern_Grek; lookup kern_Hani_Hrkt; script grek; language dflt; lookup kern_Default; lookup kern_Grek; script hani; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; script kana; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; } kern; feature dist { script dev2; language dflt; lookup kern_Default; lookup kern_Deva; script deva; language dflt; lookup kern_Default; lookup kern_Deva; script dupl; language dflt; lookup kern_Default; lookup kern_Dupl; } dist; """ ) E AssertionError: assert 'lookup kern_...l;\n} dist;\n' == 'lookup kern_...l;\n} dist;\n' E E Skipping 61 identical leading characters in diff, use -v to show E - 0 uni1CD0 7; E ? ^ E + 0 uni1CD0 3; E ? ^ E - pos uni1CE0 uni1CE0 8;... E E ...Full output truncated (218 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-None] _____________ self = designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-True] _____________ self = designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-useProductionNames.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-False] ____________ self = designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-None] ____________ self = designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-True] ____________ self = designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-useProductionNames.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ___________ IntegrationTest.test_compileVariableCFF2[ufoLib2-False] ____________ self = designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _______ IntegrationTest.test_compileVariableCFF2_subroutinized[ufoLib2] ________ self = designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) > expectTTX(varfont, "TestVariableFont-CFF2-cffsubr.ttx") tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-cffsubr.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ self = designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-post3.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ self = designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-post3.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ______________ IntegrationTest.test_compileVariableTTFs[ufoLib2] _______________ self = designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-TTF.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-TTF.ttx", ) tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-TTF.ttx +++ @@ -251,99 +251,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -417,42 +324,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -635,17 +539,17 @@ - + - + - + @@ -654,7 +558,7 @@ - + @@ -671,7 +575,7 @@ - + @@ -688,13 +592,13 @@ - + - + @@ -702,7 +606,7 @@ - + @@ -710,7 +614,7 @@ - + @@ -718,7 +622,7 @@ - + @@ -726,7 +630,7 @@ - + @@ -734,13 +638,13 @@ - + - + ______________ IntegrationTest.test_compileVariableCFF2s[ufoLib2] ______________ self = designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-CFF2.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx", ) tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx +++ @@ -128,99 +128,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -294,42 +201,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -692,17 +596,17 @@ - + - + - + @@ -711,7 +615,7 @@ - + @@ -728,7 +632,7 @@ - + @@ -745,13 +649,13 @@ - + - + @@ -759,7 +663,7 @@ - + @@ -767,7 +671,7 @@ - + @@ -775,7 +679,7 @@ - + @@ -783,7 +687,7 @@ - + @@ -791,13 +695,13 @@ - + - + _____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableTTFs] _____ self = FontClass = .ctor at 0x7f2cd9daade0> compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont ____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableCFF2s] _____ self = FontClass = .ctor at 0x7f2cd9daade0> compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont =============================== warnings summary =============================== .pybuild/cpython3_3.13_ufo2ft/build/tests/filters/dottedCircle_test.py::test_empty_font_deprecated[defcon] /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py:8: UserWarning: The dottedCircleFilter module is deprecated, please import dottedCircle instead. warnings.warn( .pybuild/cpython3_3.13_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_none[defcon-cff2] .pybuild/cpython3_3.13_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_specialize[defcon-cff2] .pybuild/cpython3_3.13_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_none[ufoLib2-cff2] .pybuild/cpython3_3.13_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_specialize[ufoLib2-cff2] /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/postProcessor.py:333: UserWarning: 'convertCFFtoCFF2' is deprecated; Use fontTools.cffLib.CFFToCFF2.convertCFFToCFF2 instead. convertCFFtoCFF2(otf) -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html --------------------------- snapshot report summary ---------------------------- 1 snapshot failed. 40 snapshots passed. =========================== short test summary info ============================ SKIPPED [2] tests/integration_test.py:137: skia-pathops is unavailable in debian yet SKIPPED [2] tests/integration_test.py:146: skia-pathops is unavailable in debian yet SKIPPED [2] tests/preProcessor_test.py:94: skia-pathops is unavailable in debian yet SKIPPED [2] tests/preProcessor_test.py:214: skia-pathops is unavailable in debian yet FAILED tests/featureWriters/kernFeatureWriter2_test.py::test_kern_zyyy_zinh[defcon] FAILED tests/featureWriters/kernFeatureWriter_test.py::test_kern_zyyy_zinh[defcon] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2_subroutinized[defcon] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTFs[defcon] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[defcon] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[defcon-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[defcon-compileVariableCFF2s] FAILED tests/featureWriters/kernFeatureWriter2_test.py::test_kern_zyyy_zinh[ufoLib2] FAILED tests/featureWriters/kernFeatureWriter_test.py::test_kern_zyyy_zinh[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2_subroutinized[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTFs[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableCFF2s] ====== 30 failed, 1102 passed, 8 skipped, 5 warnings in 112.45s (0:01:52) ====== E: pybuild pybuild:389: test: plugin distutils failed with: exit code=1: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build; python3.13 -m pytest tests I: pybuild base:311: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build; python3.12 -m pytest tests ============================= test session starts ============================== platform linux -- Python 3.12.7, pytest-8.3.3, pluggy-1.5.0 rootdir: /build/reproducible-path/ufo2ft-3.3.1 configfile: setup.cfg plugins: syrupy-4.7.2, typeguard-4.4.1 collected 1140 items tests/featureCompiler_test.py ................ [ 1%] tests/featureWriters/cursFeatureWriter_test.py ......... [ 2%] tests/featureWriters/featureWriters_test.py ........ [ 2%] tests/featureWriters/gdefFeatureWriter_test.py .......... [ 3%] tests/featureWriters/kernFeatureWriter2_test.py ........................ [ 5%] ....F..... [ 6%] tests/featureWriters/kernFeatureWriter_test.py ......................... [ 8%] ......F..... [ 10%] tests/featureWriters/markFeatureWriter_test.py ......................... [ 12%] ............ [ 13%] tests/featureWriters/variableFeatureWriter_test.py .. [ 13%] tests/filters/decomposeComponents_test.py ...... [ 13%] tests/filters/decomposeTransformedComponents_test.py ... [ 14%] tests/filters/dottedCircle_test.py ... [ 14%] tests/filters/explodeColorLayerGlyphs_test.py . [ 14%] tests/filters/flattenComponents_test.py ........ [ 15%] tests/filters/propagateAnchors_test.py ............... [ 16%] tests/filters/sortContours_test.py .... [ 16%] tests/filters/transformations_test.py ............................... [ 19%] tests/fontInfoData_test.py ................ [ 21%] tests/infoCompiler_test.py ....... [ 21%] tests/instantiator_test.py ........................... [ 24%] tests/instructionCompiler_test.py ...................................... [ 27%] ......... [ 28%] tests/integration_test.py ......s.s.............FFFFFFF...FF.....FF..... [ 32%] ..............FF. [ 33%] tests/outlineCompiler_test.py .......................................... [ 37%] ........................................................................ [ 43%] ........................ [ 45%] tests/preProcessor_test.py ....s......s.............. [ 48%] tests/util_test.py . [ 48%] tests/featureCompiler_test.py ................ [ 49%] tests/featureWriters/cursFeatureWriter_test.py ......... [ 50%] tests/featureWriters/featureWriters_test.py ........ [ 51%] tests/featureWriters/gdefFeatureWriter_test.py .......... [ 51%] tests/featureWriters/kernFeatureWriter2_test.py ........................ [ 54%] ....F..... [ 54%] tests/featureWriters/kernFeatureWriter_test.py ......................... [ 57%] ......F..... [ 58%] tests/featureWriters/markFeatureWriter_test.py ......................... [ 60%] ............ [ 61%] tests/featureWriters/variableFeatureWriter_test.py .. [ 61%] tests/filters/decomposeComponents_test.py ...... [ 62%] tests/filters/decomposeTransformedComponents_test.py ... [ 62%] tests/filters/dottedCircle_test.py ... [ 62%] tests/filters/explodeColorLayerGlyphs_test.py . [ 62%] tests/filters/flattenComponents_test.py ........ [ 63%] tests/filters/propagateAnchors_test.py ............... [ 64%] tests/filters/sortContours_test.py .... [ 65%] tests/filters/transformations_test.py ............................... [ 67%] tests/fontInfoData_test.py ................ [ 69%] tests/infoCompiler_test.py ....... [ 69%] tests/instantiator_test.py ........................... [ 72%] tests/instructionCompiler_test.py ...................................... [ 75%] ......... [ 76%] tests/integration_test.py ......s.s.............FFFFFFF...FF.....FF..... [ 80%] ..............FF. [ 81%] tests/outlineCompiler_test.py .......................................... [ 85%] ........................................................................ [ 91%] ........................ [ 93%] tests/preProcessor_test.py ....s......s.............. [ 96%] tests/util_test.py . [ 96%] tests/featureWriters/ast_test.py . [ 96%] tests/featureWriters/markFeatureWriter_test.py ......... [ 97%] tests/filters/filters_test.py ................... [ 98%] tests/filters/transformations_test.py . [ 98%] tests/fontInfoData_test.py .. [ 99%] tests/instantiator_test.py .... [ 99%] tests/instructionCompiler_test.py .... [ 99%] tests/util_test.py .. [100%] =================================== FAILURES =================================== _________________________ test_kern_zyyy_zinh[defcon] __________________________ snapshot = ''' lookup kern_dflt { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni0310 uni0310 1; pos uni03...a; language dflt; lookup kern_dflt; script dupl; language dflt; lookup kern_dflt; } dist; ''' FontClass = def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert newFeatures.asFea() == snapshot E AssertionError: assert [+ received] == [- snapshot] E ''' E ... E lookupflag IgnoreMarks; E - pos uni0300 uni0300 0; E - pos uni0310 uni0310 1; E - pos uni0320 uni0320 2; E - pos uni0330 uni0330 3;... E E ...Full output truncated (85 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[defcon] __________________________ FontClass = def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert dedent(str(newFeatures)) == dedent( """\ lookup kern_Deva { lookupflag IgnoreMarks; pos uni1CD0 uni1CD0 7; pos uni1CE0 uni1CE0 8; pos uni1CF0 uni1CF0 9; pos uni20F0 uni20F0 11; pos uniA830 uniA830 34; } kern_Deva; lookup kern_Dupl { lookupflag IgnoreMarks; pos uni1BCA0 uni1BCA0 42; } kern_Dupl; lookup kern_Grek { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni1DC0 uni1DC0 10; } kern_Grek; lookup kern_Hani_Hrkt { lookupflag IgnoreMarks; pos uni1D360 uni1D360 43; pos uni1D370 uni1D370 44; pos uni1F250 uni1F250 45; pos uni2FF0 uni2FF0 13; pos uni3010 uni3010 14; pos uni3030 uni3030 15; pos uni30A0 uni30A0 16; pos uni3190 uni3190 17; pos uni31C0 uni31C0 18; pos uni31D0 uni31D0 19; pos uni31E0 uni31E0 20; pos uni3220 uni3220 21; pos uni3230 uni3230 22; pos uni3240 uni3240 23; pos uni3280 uni3280 24; pos uni3290 uni3290 25; pos uni32A0 uni32A0 26; pos uni32B0 uni32B0 27; pos uni32C0 uni32C0 28; pos uni3360 uni3360 29; pos uni3370 uni3370 30; pos uni33E0 uni33E0 31; pos uni33F0 uni33F0 32; pos uniA700 uniA700 33; pos uniFF70 uniFF70 35; } kern_Hani_Hrkt; lookup kern_Default { lookupflag IgnoreMarks; pos uni0310 uni0310 1; pos uni0320 uni0320 2; pos uni0330 uni0330 3; pos uni0640 uni0640 4; pos uni0650 uni0650 5; pos uni0670 uni0670 6; pos uni10100 uni10100 36; pos uni10110 uni10110 37; pos uni10120 uni10120 38; pos uni10130 uni10130 39; pos uni102E0 uni102E0 40; pos uni102F0 uni102F0 41; pos uni2E30 uni2E30 12; } kern_Default; feature kern { script DFLT; language dflt; lookup kern_Default; lookup kern_Grek; lookup kern_Hani_Hrkt; script grek; language dflt; lookup kern_Default; lookup kern_Grek; script hani; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; script kana; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; } kern; feature dist { script dev2; language dflt; lookup kern_Default; lookup kern_Deva; script deva; language dflt; lookup kern_Default; lookup kern_Deva; script dupl; language dflt; lookup kern_Default; lookup kern_Dupl; } dist; """ ) E AssertionError: assert 'lookup kern_...l;\n} dist;\n' == 'lookup kern_...l;\n} dist;\n' E E Skipping 61 identical leading characters in diff, use -v to show E - 0 uni1CD0 7; E ? ^ E + 0 uni1CD0 3; E ? ^ E - pos uni1CE0 uni1CE0 8;... E E ...Full output truncated (218 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError _____________ IntegrationTest.test_compileVariableTTF[defcon-None] _____________ self = designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _____________ IntegrationTest.test_compileVariableTTF[defcon-True] _____________ self = designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-useProductionNames.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[defcon-False] _____________ self = designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-None] _____________ self = designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-True] _____________ self = designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-useProductionNames.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-False] ____________ self = designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ________ IntegrationTest.test_compileVariableCFF2_subroutinized[defcon] ________ self = designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) > expectTTX(varfont, "TestVariableFont-CFF2-cffsubr.ttx") tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-cffsubr.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ self = designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-post3.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ self = designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-post3.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _______________ IntegrationTest.test_compileVariableTTFs[defcon] _______________ self = designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-TTF.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-TTF.ttx", ) tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-TTF.ttx +++ @@ -251,99 +251,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -417,42 +324,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -635,17 +539,17 @@ - + - + - + @@ -654,7 +558,7 @@ - + @@ -671,7 +575,7 @@ - + @@ -688,13 +592,13 @@ - + - + @@ -702,7 +606,7 @@ - + @@ -710,7 +614,7 @@ - + @@ -718,7 +622,7 @@ - + @@ -726,7 +630,7 @@ - + @@ -734,13 +638,13 @@ - + - + ______________ IntegrationTest.test_compileVariableCFF2s[defcon] _______________ self = designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-CFF2.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx", ) tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx +++ @@ -128,99 +128,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -294,42 +201,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -692,17 +596,17 @@ - + - + - + @@ -711,7 +615,7 @@ - + @@ -728,7 +632,7 @@ - + @@ -745,13 +649,13 @@ - + - + @@ -759,7 +663,7 @@ - + @@ -767,7 +671,7 @@ - + @@ -775,7 +679,7 @@ - + @@ -783,7 +687,7 @@ - + @@ -791,13 +695,13 @@ - + - + _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableTTFs] ______ self = FontClass = compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableCFF2s] _____ self = FontClass = compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ snapshot = ''' lookup kern_dflt { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni0310 uni0310 1; pos uni03...a; language dflt; lookup kern_dflt; script dupl; language dflt; lookup kern_dflt; } dist; ''' FontClass = .ctor at 0x7ff561e9a020> def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert newFeatures.asFea() == snapshot E AssertionError: assert [+ received] == [- snapshot] E ''' E ... E lookupflag IgnoreMarks; E - pos uni0300 uni0300 0; E - pos uni0310 uni0310 1; E - pos uni0320 uni0320 2; E - pos uni0330 uni0330 3;... E E ...Full output truncated (85 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ FontClass = .ctor at 0x7ff561e9a020> def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert dedent(str(newFeatures)) == dedent( """\ lookup kern_Deva { lookupflag IgnoreMarks; pos uni1CD0 uni1CD0 7; pos uni1CE0 uni1CE0 8; pos uni1CF0 uni1CF0 9; pos uni20F0 uni20F0 11; pos uniA830 uniA830 34; } kern_Deva; lookup kern_Dupl { lookupflag IgnoreMarks; pos uni1BCA0 uni1BCA0 42; } kern_Dupl; lookup kern_Grek { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni1DC0 uni1DC0 10; } kern_Grek; lookup kern_Hani_Hrkt { lookupflag IgnoreMarks; pos uni1D360 uni1D360 43; pos uni1D370 uni1D370 44; pos uni1F250 uni1F250 45; pos uni2FF0 uni2FF0 13; pos uni3010 uni3010 14; pos uni3030 uni3030 15; pos uni30A0 uni30A0 16; pos uni3190 uni3190 17; pos uni31C0 uni31C0 18; pos uni31D0 uni31D0 19; pos uni31E0 uni31E0 20; pos uni3220 uni3220 21; pos uni3230 uni3230 22; pos uni3240 uni3240 23; pos uni3280 uni3280 24; pos uni3290 uni3290 25; pos uni32A0 uni32A0 26; pos uni32B0 uni32B0 27; pos uni32C0 uni32C0 28; pos uni3360 uni3360 29; pos uni3370 uni3370 30; pos uni33E0 uni33E0 31; pos uni33F0 uni33F0 32; pos uniA700 uniA700 33; pos uniFF70 uniFF70 35; } kern_Hani_Hrkt; lookup kern_Default { lookupflag IgnoreMarks; pos uni0310 uni0310 1; pos uni0320 uni0320 2; pos uni0330 uni0330 3; pos uni0640 uni0640 4; pos uni0650 uni0650 5; pos uni0670 uni0670 6; pos uni10100 uni10100 36; pos uni10110 uni10110 37; pos uni10120 uni10120 38; pos uni10130 uni10130 39; pos uni102E0 uni102E0 40; pos uni102F0 uni102F0 41; pos uni2E30 uni2E30 12; } kern_Default; feature kern { script DFLT; language dflt; lookup kern_Default; lookup kern_Grek; lookup kern_Hani_Hrkt; script grek; language dflt; lookup kern_Default; lookup kern_Grek; script hani; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; script kana; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; } kern; feature dist { script dev2; language dflt; lookup kern_Default; lookup kern_Deva; script deva; language dflt; lookup kern_Default; lookup kern_Deva; script dupl; language dflt; lookup kern_Default; lookup kern_Dupl; } dist; """ ) E AssertionError: assert 'lookup kern_...l;\n} dist;\n' == 'lookup kern_...l;\n} dist;\n' E E Skipping 61 identical leading characters in diff, use -v to show E - 0 uni1CD0 7; E ? ^ E + 0 uni1CD0 3; E ? ^ E - pos uni1CE0 uni1CE0 8;... E E ...Full output truncated (218 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-None] _____________ self = designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-True] _____________ self = designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-useProductionNames.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-False] ____________ self = designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-None] ____________ self = designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-True] ____________ self = designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-useProductionNames.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ___________ IntegrationTest.test_compileVariableCFF2[ufoLib2-False] ____________ self = designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _______ IntegrationTest.test_compileVariableCFF2_subroutinized[ufoLib2] ________ self = designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) > expectTTX(varfont, "TestVariableFont-CFF2-cffsubr.ttx") tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-cffsubr.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ self = designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-post3.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ self = designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-post3.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ______________ IntegrationTest.test_compileVariableTTFs[ufoLib2] _______________ self = designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-TTF.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-TTF.ttx", ) tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-TTF.ttx +++ @@ -251,99 +251,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -417,42 +324,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -635,17 +539,17 @@ - + - + - + @@ -654,7 +558,7 @@ - + @@ -671,7 +575,7 @@ - + @@ -688,13 +592,13 @@ - + - + @@ -702,7 +606,7 @@ - + @@ -710,7 +614,7 @@ - + @@ -718,7 +622,7 @@ - + @@ -726,7 +630,7 @@ - + @@ -734,13 +638,13 @@ - + - + ______________ IntegrationTest.test_compileVariableCFF2s[ufoLib2] ______________ self = designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-CFF2.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx", ) tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx +++ @@ -128,99 +128,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -294,42 +201,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -692,17 +596,17 @@ - + - + - + @@ -711,7 +615,7 @@ - + @@ -728,7 +632,7 @@ - + @@ -745,13 +649,13 @@ - + - + @@ -759,7 +663,7 @@ - + @@ -767,7 +671,7 @@ - + @@ -775,7 +679,7 @@ - + @@ -783,7 +687,7 @@ - + @@ -791,13 +695,13 @@ - + - + _____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableTTFs] _____ self = FontClass = .ctor at 0x7ff561e9a020> compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont ____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableCFF2s] _____ self = FontClass = .ctor at 0x7ff561e9a020> compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont =============================== warnings summary =============================== .pybuild/cpython3_3.12_ufo2ft/build/tests/filters/dottedCircle_test.py::test_empty_font_deprecated[defcon] /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py:8: UserWarning: The dottedCircleFilter module is deprecated, please import dottedCircle instead. warnings.warn( .pybuild/cpython3_3.12_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_none[defcon-cff2] .pybuild/cpython3_3.12_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_specialize[defcon-cff2] .pybuild/cpython3_3.12_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_none[ufoLib2-cff2] .pybuild/cpython3_3.12_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_specialize[ufoLib2-cff2] /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/postProcessor.py:333: UserWarning: 'convertCFFtoCFF2' is deprecated; Use fontTools.cffLib.CFFToCFF2.convertCFFToCFF2 instead. convertCFFtoCFF2(otf) -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html --------------------------- snapshot report summary ---------------------------- 1 snapshot failed. 40 snapshots passed. =========================== short test summary info ============================ SKIPPED [2] tests/integration_test.py:137: skia-pathops is unavailable in debian yet SKIPPED [2] tests/integration_test.py:146: skia-pathops is unavailable in debian yet SKIPPED [2] tests/preProcessor_test.py:94: skia-pathops is unavailable in debian yet SKIPPED [2] tests/preProcessor_test.py:214: skia-pathops is unavailable in debian yet FAILED tests/featureWriters/kernFeatureWriter2_test.py::test_kern_zyyy_zinh[defcon] FAILED tests/featureWriters/kernFeatureWriter_test.py::test_kern_zyyy_zinh[defcon] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2_subroutinized[defcon] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTFs[defcon] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[defcon] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[defcon-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[defcon-compileVariableCFF2s] FAILED tests/featureWriters/kernFeatureWriter2_test.py::test_kern_zyyy_zinh[ufoLib2] FAILED tests/featureWriters/kernFeatureWriter_test.py::test_kern_zyyy_zinh[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2_subroutinized[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTFs[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableCFF2s] ====== 30 failed, 1102 passed, 8 skipped, 5 warnings in 74.24s (0:01:14) ======= E: pybuild pybuild:389: test: plugin distutils failed with: exit code=1: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build; python3.12 -m pytest tests dh_auto_test: error: pybuild --test --test-pytest -i python{version} -p "3.13 3.12" returned exit code 13 make[1]: [debian/rules:15: override_dh_auto_test] Error 25 (ignored) make[1]: Leaving directory '/build/reproducible-path/ufo2ft-3.3.1' create-stamp debian/debhelper-build-stamp fakeroot debian/rules binary dh binary --buildsystem=pybuild dh_testroot -O--buildsystem=pybuild dh_prep -O--buildsystem=pybuild dh_auto_install --destdir=debian/python3-ufo2ft/ -O--buildsystem=pybuild I: pybuild base:311: /usr/bin/python3.13 setup.py install --root /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running install /usr/lib/python3/dist-packages/setuptools/_distutils/cmd.py:66: SetuptoolsDeprecationWarning: setup.py install is deprecated. !! ******************************************************************************** Please avoid running ``setup.py`` directly. Instead, use pypa/build, pypa/installer or other standards-based tools. See https://blog.ganssle.io/articles/2021/10/setup-py-deprecated.html for details. ******************************************************************************** !! self.initialize_options() running build running build_py copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft running egg_info writing Lib/ufo2ft.egg-info/PKG-INFO writing dependency_links to Lib/ufo2ft.egg-info/dependency_links.txt writing requirements to Lib/ufo2ft.egg-info/requires.txt writing top-level names to Lib/ufo2ft.egg-info/top_level.txt reading manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' adding license file 'LICENSE' writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' running install_lib creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/baseCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableTTFCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/ttfCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableTTFsCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableOTFCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableCFF2sCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/otfCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/cubicToQuadratic.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/propagateAnchors.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/explodeColorLayerGlyphs.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeTransformedComponents.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/reverseContourDirection.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/skipExportGlyphs.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/sortContours.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircleFilter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircle.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/base.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/transformations.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/removeOverlaps.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeComponents.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/flattenComponents.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/postProcessor.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/constants.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/outlineCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/instantiator.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/infoCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/fontInfoData.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/util.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/featureCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/instructionCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/errors.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/preProcessor.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/_version.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/baseFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/gdefFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/cursFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/ast.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter2.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/markFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/maxContextCalc.py to maxContextCalc.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/preProcessor.py to preProcessor.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/interpolatableTTFCompiler.py to interpolatableTTFCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/baseCompiler.py to baseCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/ttfCompiler.py to ttfCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/interpolatableOTFCompiler.py to interpolatableOTFCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/variableCFF2sCompiler.py to variableCFF2sCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/otfCompiler.py to otfCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/variableTTFsCompiler.py to variableTTFsCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/constants.py to constants.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/outlineCompiler.py to outlineCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_version.py to _version.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/removeOverlaps.py to removeOverlaps.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/skipExportGlyphs.py to skipExportGlyphs.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/reverseContourDirection.py to reverseContourDirection.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/explodeColorLayerGlyphs.py to explodeColorLayerGlyphs.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/decomposeTransformedComponents.py to decomposeTransformedComponents.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/flattenComponents.py to flattenComponents.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/dottedCircleFilter.py to dottedCircleFilter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/base.py to base.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__main__.py to __main__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/decomposeComponents.py to decomposeComponents.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/transformations.py to transformations.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/dottedCircle.py to dottedCircle.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/cubicToQuadratic.py to cubicToQuadratic.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/sortContours.py to sortContours.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/propagateAnchors.py to propagateAnchors.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/infoCompiler.py to infoCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/fontInfoData.py to fontInfoData.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/instantiator.py to instantiator.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/postProcessor.py to postProcessor.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/instructionCompiler.py to instructionCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/kernFeatureWriter2.py to kernFeatureWriter2.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/baseFeatureWriter.py to baseFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/ast.py to ast.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/cursFeatureWriter.py to cursFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/gdefFeatureWriter.py to gdefFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__main__.py to __main__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/markFeatureWriter.py to markFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/kernFeatureWriter.py to kernFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/util.py to util.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/errors.py to errors.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureCompiler.py to featureCompiler.cpython-313.pyc running install_egg_info Copying Lib/ufo2ft.egg-info to /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft-3.3.1.egg-info Skipping SOURCES.txt running install_scripts I: pybuild base:311: /usr/bin/python3 setup.py install --root /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running install /usr/lib/python3/dist-packages/setuptools/_distutils/cmd.py:66: SetuptoolsDeprecationWarning: setup.py install is deprecated. !! ******************************************************************************** Please avoid running ``setup.py`` directly. Instead, use pypa/build, pypa/installer or other standards-based tools. See https://blog.ganssle.io/articles/2021/10/setup-py-deprecated.html for details. ******************************************************************************** !! self.initialize_options() running build running build_py copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft running egg_info writing Lib/ufo2ft.egg-info/PKG-INFO writing dependency_links to Lib/ufo2ft.egg-info/dependency_links.txt writing requirements to Lib/ufo2ft.egg-info/requires.txt writing top-level names to Lib/ufo2ft.egg-info/top_level.txt reading manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' adding license file 'LICENSE' writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' running install_lib creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/otfCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableTTFsCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableOTFCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/ttfCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableTTFCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableCFF2sCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/baseCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/explodeColorLayerGlyphs.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircle.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/cubicToQuadratic.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeTransformedComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/propagateAnchors.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/base.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/flattenComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/reverseContourDirection.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/removeOverlaps.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/transformations.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/sortContours.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/skipExportGlyphs.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircleFilter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/outlineCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/preProcessor.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/errors.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/postProcessor.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/infoCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/instructionCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/fontInfoData.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/_version.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/featureCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/instantiator.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/constants.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/util.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter2.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/markFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/ast.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/gdefFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/baseFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/cursFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/maxContextCalc.py to maxContextCalc.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/preProcessor.py to preProcessor.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/interpolatableTTFCompiler.py to interpolatableTTFCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/baseCompiler.py to baseCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/ttfCompiler.py to ttfCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/interpolatableOTFCompiler.py to interpolatableOTFCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/variableCFF2sCompiler.py to variableCFF2sCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/otfCompiler.py to otfCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/variableTTFsCompiler.py to variableTTFsCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/constants.py to constants.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/outlineCompiler.py to outlineCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_version.py to _version.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/removeOverlaps.py to removeOverlaps.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/skipExportGlyphs.py to skipExportGlyphs.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/reverseContourDirection.py to reverseContourDirection.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/explodeColorLayerGlyphs.py to explodeColorLayerGlyphs.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/decomposeTransformedComponents.py to decomposeTransformedComponents.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/flattenComponents.py to flattenComponents.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/dottedCircleFilter.py to dottedCircleFilter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/base.py to base.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__main__.py to __main__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/decomposeComponents.py to decomposeComponents.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/transformations.py to transformations.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/dottedCircle.py to dottedCircle.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/cubicToQuadratic.py to cubicToQuadratic.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/sortContours.py to sortContours.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/propagateAnchors.py to propagateAnchors.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/infoCompiler.py to infoCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/fontInfoData.py to fontInfoData.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/instantiator.py to instantiator.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/postProcessor.py to postProcessor.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/instructionCompiler.py to instructionCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/kernFeatureWriter2.py to kernFeatureWriter2.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/baseFeatureWriter.py to baseFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/ast.py to ast.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/cursFeatureWriter.py to cursFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/gdefFeatureWriter.py to gdefFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__main__.py to __main__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/markFeatureWriter.py to markFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/kernFeatureWriter.py to kernFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/util.py to util.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/errors.py to errors.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureCompiler.py to featureCompiler.cpython-312.pyc running install_egg_info Copying Lib/ufo2ft.egg-info to /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft-3.3.1.egg-info Skipping SOURCES.txt running install_scripts dh_installdocs -O--buildsystem=pybuild dh_installchangelogs -O--buildsystem=pybuild dh_python3 -O--buildsystem=pybuild dh_installsystemduser -O--buildsystem=pybuild dh_perl -O--buildsystem=pybuild dh_link -O--buildsystem=pybuild dh_strip_nondeterminism -O--buildsystem=pybuild dh_compress -O--buildsystem=pybuild dh_fixperms -O--buildsystem=pybuild dh_missing -O--buildsystem=pybuild dh_installdeb -O--buildsystem=pybuild dh_gencontrol -O--buildsystem=pybuild dh_md5sums -O--buildsystem=pybuild dh_builddeb -O--buildsystem=pybuild dpkg-deb: building package 'python3-ufo2ft' in '../python3-ufo2ft_3.3.1-2_all.deb'. dpkg-genbuildinfo --build=binary -O../ufo2ft_3.3.1-2_amd64.buildinfo dpkg-genchanges --build=binary -O../ufo2ft_3.3.1-2_amd64.changes dpkg-genchanges: info: binary-only upload (no source code included) dpkg-source --after-build . dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: not including original source code in upload I: copying local configuration I: unmounting dev/ptmx filesystem I: unmounting dev/pts filesystem I: unmounting dev/shm filesystem I: unmounting proc filesystem I: unmounting sys filesystem I: cleaning the build env I: removing directory /srv/workspace/pbuilder/894615 and its subdirectories I: Current time: Sun Nov 24 07:33:14 -12 2024 I: pbuilder-time-stamp: 1732476794 Sun Nov 24 19:33:15 UTC 2024 I: 1st build successful. Starting 2nd build on remote node ionos15-amd64.debian.net. Sun Nov 24 19:33:16 UTC 2024 I: Preparing to do remote build '2' on ionos15-amd64.debian.net. Sun Nov 24 19:33:16 UTC 2024 - checking /var/lib/jenkins/offline_nodes if ionos15-amd64.debian.net is marked as down. Sun Nov 24 19:33:16 UTC 2024 - checking via ssh if ionos15-amd64.debian.net is up. removed '/tmp/read-only-fs-test-kCDea2' ==================================================================================== Sun Dec 28 01:56:16 UTC 2025 - running /srv/jenkins/bin/reproducible_build.sh (for job /srv/jenkins/bin/reproducible_build.sh) on ionos15-amd64, called using "2 ufo2ft unstable /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf 3.3.1-2" as arguments. Sun Dec 28 01:56:16 UTC 2025 - actually running "reproducible_build.sh" (md5sum 68e686e434c9ab7bc3ec047d8b309cbc) as "/tmp/jenkins-script-Abn2TQCR" $ git clone https://salsa.debian.org/qa/jenkins.debian.net.git ; more CONTRIBUTING Sun Dec 28 01:56:16 UTC 2025 I: Downloading source for unstable/ufo2ft=3.3.1-2 Reading package lists... NOTICE: 'ufo2ft' packaging is maintained in the 'Git' version control system at: https://salsa.debian.org/fonts-team/ufo2ft.git Please use: git clone https://salsa.debian.org/fonts-team/ufo2ft.git to retrieve the latest (possibly unreleased) updates to the package. Need to get 408 kB of source archives. Get:1 http://deb.debian.org/debian unstable/main ufo2ft 3.3.1-2 (dsc) [2508 B] Get:2 http://deb.debian.org/debian unstable/main ufo2ft 3.3.1-2 (tar) [399 kB] Get:3 http://deb.debian.org/debian unstable/main ufo2ft 3.3.1-2 (diff) [6224 B] Fetched 408 kB in 0s (14.2 MB/s) Download complete and in download only mode Reading package lists... NOTICE: 'ufo2ft' packaging is maintained in the 'Git' version control system at: https://salsa.debian.org/fonts-team/ufo2ft.git Please use: git clone https://salsa.debian.org/fonts-team/ufo2ft.git to retrieve the latest (possibly unreleased) updates to the package. Need to get 408 kB of source archives. Get:1 http://deb.debian.org/debian unstable/main ufo2ft 3.3.1-2 (dsc) [2508 B] Get:2 http://deb.debian.org/debian unstable/main ufo2ft 3.3.1-2 (tar) [399 kB] Get:3 http://deb.debian.org/debian unstable/main ufo2ft 3.3.1-2 (diff) [6224 B] Fetched 408 kB in 0s (14.2 MB/s) Download complete and in download only mode ============================================================================= Re-Building ufo2ft in unstable on amd64 on ionos15-amd64 now. Date: Sun Dec 28 01:56:17 UTC 2025 Date UTC: Sun Dec 28 01:56:17 UTC 2025 ============================================================================= ++ mktemp -t pbuilderrc_XXXX --tmpdir=/srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf + local TMPCFG=/srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/pbuilderrc_T0kl + case ${ARCH} in + case $ARCH in + locale=et_EE + language=et + case "${SUITE}" in + reproducible_buildflags=+all + extra_deb_build_options= + case "${SRCPACKAGE}" in + cat + echo BUILDDIR=/build/reproducible-path + '[' ufo2ft = debian-installer -o ufo2ft = debian-installer-netboot-images ']' + pbuilder_options=() + local pbuilder_options + DEBBUILDOPTS=-b + BINARYTARGET= + '[' ufo2ft = u-boot ']' + case "${SRCPACKAGE}" in + PBUILDERTIMEOUT=24 + local PRESULT=0 + sudo timeout -k 24.1h 24h /usr/bin/ionice -c 3 /usr/bin/nice -n 11 /usr/bin/unshare --uts -- /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/pbuilderrc_T0kl --distribution unstable --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b2 --logfile b2/build.log ufo2ft_3.3.1-2.dsc W: /root/.pbuilderrc does not exist I: Logging to b2/build.log I: pbuilder: network access will be disabled during build I: Current time: Sun Dec 28 15:56:17 +14 2025 I: pbuilder-time-stamp: 1766886977 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/unstable-reproducible-base.tgz] I: copying local configuration W: --override-config is not set; not updating apt.conf Read the manpage for details. I: mounting /proc filesystem I: mounting /sys filesystem I: creating /{dev,run}/shm I: mounting /dev/pts filesystem I: redirecting /dev/ptmx to /dev/pts/ptmx I: policy-rc.d already exists I: Copying source file I: copying [ufo2ft_3.3.1-2.dsc] I: copying [./ufo2ft_3.3.1.orig.tar.gz] I: copying [./ufo2ft_3.3.1-2.debian.tar.xz] I: Extracting source gpgv: Signature made Wed Oct 23 13:31:24 2024 gpgv: using RSA key 7E7729476D87D6F11D91ACCBC293E7B461825ACE gpgv: Can't check signature: No public key dpkg-source: warning: cannot verify inline signature for ./ufo2ft_3.3.1-2.dsc: no acceptable signature found dpkg-source: info: extracting ufo2ft in ufo2ft-3.3.1 dpkg-source: info: unpacking ufo2ft_3.3.1.orig.tar.gz dpkg-source: info: unpacking ufo2ft_3.3.1-2.debian.tar.xz dpkg-source: info: using patch list from debian/patches/series dpkg-source: info: applying disable-pathops-test.patch dpkg-source: info: applying Add-files-to-avoid-clean-target-failure.patch I: using fakeroot in build. I: Installing the build-deps I: user script /srv/workspace/pbuilder/501244/tmp/hooks/D01_modify_environment starting debug: Running on ionos15-amd64. I: Changing host+domainname to test build reproducibility I: Adding a custom variable just for the fun of it... I: Changing /bin/sh to bash '/bin/sh' -> '/bin/bash' lrwxrwxrwx 1 root root 9 Dec 28 01:56 /bin/sh -> /bin/bash I: Setting pbuilder2's login shell to /bin/bash I: Setting pbuilder2's GECOS to second user,second room,second work-phone,second home-phone,second other I: user script /srv/workspace/pbuilder/501244/tmp/hooks/D01_modify_environment finished I: user script /srv/workspace/pbuilder/501244/tmp/hooks/D02_print_environment starting I: set BASH=/bin/sh BASHOPTS=checkwinsize:cmdhist:complete_fullquote:extquote:force_fignore:globasciiranges:globskipdots:hostcomplete:interactive_comments:patsub_replacement:progcomp:promptvars:sourcepath BASH_ALIASES=() BASH_ARGC=() BASH_ARGV=() BASH_CMDS=() BASH_LINENO=([0]="12" [1]="0") BASH_LOADABLES_PATH=/usr/local/lib/bash:/usr/lib/bash:/opt/local/lib/bash:/usr/pkg/lib/bash:/opt/pkg/lib/bash:. BASH_SOURCE=([0]="/tmp/hooks/D02_print_environment" [1]="/tmp/hooks/D02_print_environment") BASH_VERSINFO=([0]="5" [1]="2" [2]="32" [3]="1" [4]="release" [5]="x86_64-pc-linux-gnu") BASH_VERSION='5.2.32(1)-release' BUILDDIR=/build/reproducible-path BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' BUILDUSERNAME=pbuilder2 BUILD_ARCH=amd64 DEBIAN_FRONTEND=noninteractive DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=42 ' DIRSTACK=() DISTRIBUTION=unstable EUID=0 FUNCNAME=([0]="Echo" [1]="main") GROUPS=() HOME=/root HOSTNAME=i-capture-the-hostname HOSTTYPE=x86_64 HOST_ARCH=amd64 IFS=' ' INVOCATION_ID=f22def810bd54dc1b6b299343c78a235 LANG=C LANGUAGE=et_EE:et LC_ALL=C MACHTYPE=x86_64-pc-linux-gnu MAIL=/var/mail/root OPTERR=1 OPTIND=1 OSTYPE=linux-gnu PATH=/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path PBCURRENTCOMMANDLINEOPERATION=build PBUILDER_OPERATION=build PBUILDER_PKGDATADIR=/usr/share/pbuilder PBUILDER_PKGLIBDIR=/usr/lib/pbuilder PBUILDER_SYSCONFDIR=/etc PIPESTATUS=([0]="0") POSIXLY_CORRECT=y PPID=501244 PS4='+ ' PWD=/ SHELL=/bin/bash SHELLOPTS=braceexpand:errexit:hashall:interactive-comments:posix SHLVL=3 SUDO_COMMAND='/usr/bin/timeout -k 24.1h 24h /usr/bin/ionice -c 3 /usr/bin/nice -n 11 /usr/bin/unshare --uts -- /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/pbuilderrc_T0kl --distribution unstable --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b2 --logfile b2/build.log ufo2ft_3.3.1-2.dsc' SUDO_GID=111 SUDO_UID=106 SUDO_USER=jenkins TERM=unknown TZ=/usr/share/zoneinfo/Etc/GMT-14 UID=0 USER=root _='I: set' http_proxy=http://213.165.73.152:3128 I: uname -a Linux i-capture-the-hostname 6.11.5+bpo-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.11.5-1~bpo12+1 (2024-11-11) x86_64 GNU/Linux I: ls -l /bin lrwxrwxrwx 1 root root 7 Nov 22 2024 /bin -> usr/bin I: user script /srv/workspace/pbuilder/501244/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy Version: 0.invalid.0 Architecture: amd64 Maintainer: Debian Pbuilder Team Description: Dummy package to satisfy dependencies with aptitude - created by pbuilder This package was created automatically by pbuilder to satisfy the build-dependencies of the package being currently built. Depends: debhelper-compat (= 13), dh-sequence-python3, python3-all, python3-setuptools, python3-setuptools-scm, python3-pytest, python3-fontmath, python3-fonttools (>= 4.50.0), python3-ufolib2 (>= 0.16.0), python3-defcon (>= 0.10.0), python3-syrupy, python3-compreffor (>= 0.5.5), python3-booleanoperations (>= 0.9.0), python3-cffsubr (>= 0.2.9) dpkg-deb: building package 'pbuilder-satisfydepends-dummy' in '/tmp/satisfydepends-aptitude/pbuilder-satisfydepends-dummy.deb'. Selecting previously unselected package pbuilder-satisfydepends-dummy. (Reading database ... 19966 files and directories currently installed.) Preparing to unpack .../pbuilder-satisfydepends-dummy.deb ... Unpacking pbuilder-satisfydepends-dummy (0.invalid.0) ... dpkg: pbuilder-satisfydepends-dummy: dependency problems, but configuring anyway as you requested: pbuilder-satisfydepends-dummy depends on debhelper-compat (= 13); however: Package debhelper-compat is not installed. pbuilder-satisfydepends-dummy depends on dh-sequence-python3; however: Package dh-sequence-python3 is not installed. pbuilder-satisfydepends-dummy depends on python3-all; however: Package python3-all is not installed. pbuilder-satisfydepends-dummy depends on python3-setuptools; however: Package python3-setuptools is not installed. pbuilder-satisfydepends-dummy depends on python3-setuptools-scm; however: Package python3-setuptools-scm is not installed. pbuilder-satisfydepends-dummy depends on python3-pytest; however: Package python3-pytest is not installed. pbuilder-satisfydepends-dummy depends on python3-fontmath; however: Package python3-fontmath is not installed. pbuilder-satisfydepends-dummy depends on python3-fonttools (>= 4.50.0); however: Package python3-fonttools is not installed. pbuilder-satisfydepends-dummy depends on python3-ufolib2 (>= 0.16.0); however: Package python3-ufolib2 is not installed. pbuilder-satisfydepends-dummy depends on python3-defcon (>= 0.10.0); however: Package python3-defcon is not installed. pbuilder-satisfydepends-dummy depends on python3-syrupy; however: Package python3-syrupy is not installed. pbuilder-satisfydepends-dummy depends on python3-compreffor (>= 0.5.5); however: Package python3-compreffor is not installed. pbuilder-satisfydepends-dummy depends on python3-booleanoperations (>= 0.9.0); however: Package python3-booleanoperations is not installed. pbuilder-satisfydepends-dummy depends on python3-cffsubr (>= 0.2.9); however: Package python3-cffsubr is not installed. Setting up pbuilder-satisfydepends-dummy (0.invalid.0) ... Reading package lists... Building dependency tree... Reading state information... Initializing package states... Writing extended state information... Building tag database... pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) The following NEW packages will be installed: afdko-bin{a} autoconf{a} automake{a} autopoint{a} autotools-dev{a} bsdextrautils{a} debhelper{a} dh-autoreconf{a} dh-python{a} dh-strip-nondeterminism{a} dwz{a} file{a} gettext{a} gettext-base{a} groff-base{a} intltool-debian{a} libantlr4-runtime4.9{a} libarchive-zip-perl{a} libblas3{a} libcom-err2{a} libdebhelper-perl{a} libelf1t64{a} libexpat1{a} libfile-stripnondeterminism-perl{a} libgfortran5{a} libgssapi-krb5-2{a} libicu72{a} libjs-jquery{a} libjs-sphinxdoc{a} libjs-underscore{a} libk5crypto3{a} libkeyutils1{a} libkrb5-3{a} libkrb5support0{a} liblapack3{a} liblbfgsb0{a} libmagic-mgc{a} libmagic1t64{a} libnsl2{a} libpipeline1{a} libpython3-stdlib{a} libpython3.12-minimal{a} libpython3.12-stdlib{a} libpython3.13-minimal{a} libpython3.13-stdlib{a} libreadline8t64{a} libtirpc-common{a} libtirpc3t64{a} libtool{a} libuchardet0{a} libxml2{a} libxslt1.1{a} m4{a} man-db{a} media-types{a} netbase{a} po-debconf{a} python3{a} python3-all{a} python3-appdirs{a} python3-attr{a} python3-autocommand{a} python3-booleanoperations{a} python3-brotli{a} python3-cffsubr{a} python3-compreffor{a} python3-decorator{a} python3-defcon{a} python3-fontmath{a} python3-fonttools{a} python3-fs{a} python3-inflect{a} python3-iniconfig{a} python3-jaraco.context{a} python3-jaraco.functools{a} python3-jaraco.text{a} python3-lxml{a} python3-lz4{a} python3-minimal{a} python3-more-itertools{a} python3-mpmath{a} python3-numpy{a} python3-packaging{a} python3-pkg-resources{a} python3-pluggy{a} python3-pyclipper{a} python3-pytest{a} python3-scipy{a} python3-setuptools{a} python3-setuptools-scm{a} python3-six{a} python3-sympy{a} python3-syrupy{a} python3-typeguard{a} python3-typing-extensions{a} python3-tz{a} python3-ufolib2{a} python3-zipp{a} python3.12{a} python3.12-minimal{a} python3.13{a} python3.13-minimal{a} readline-common{a} sensible-utils{a} tzdata{a} unicode-data{a} The following packages are RECOMMENDED but will NOT be installed: ca-certificates curl isympy-common javascript-common krb5-locales libarchive-cpio-perl libltdl-dev libmail-sendmail-perl lynx python3-bs4 python3-cssselect python3-fontpens python3-html5lib python3-pil python3-pooch python3-pygments wget 0 packages upgraded, 106 newly installed, 0 to remove and 0 not upgraded. Need to get 82.8 MB of archives. After unpacking 407 MB will be used. Writing extended state information... Get: 1 http://deb.debian.org/debian unstable/main amd64 libpython3.12-minimal amd64 3.12.7-3 [815 kB] Get: 2 http://deb.debian.org/debian unstable/main amd64 libexpat1 amd64 2.6.4-1 [106 kB] Get: 3 http://deb.debian.org/debian unstable/main amd64 python3.12-minimal amd64 3.12.7-3 [2162 kB] Get: 4 http://deb.debian.org/debian unstable/main amd64 python3-minimal amd64 3.12.7-1 [26.8 kB] Get: 5 http://deb.debian.org/debian unstable/main amd64 media-types all 10.1.0 [26.9 kB] Get: 6 http://deb.debian.org/debian unstable/main amd64 netbase all 6.4 [12.8 kB] Get: 7 http://deb.debian.org/debian unstable/main amd64 tzdata all 2024b-3 [255 kB] Get: 8 http://deb.debian.org/debian unstable/main amd64 libkrb5support0 amd64 1.21.3-3 [32.5 kB] Get: 9 http://deb.debian.org/debian unstable/main amd64 libcom-err2 amd64 1.47.1-1+b1 [23.2 kB] Get: 10 http://deb.debian.org/debian unstable/main amd64 libk5crypto3 amd64 1.21.3-3 [79.9 kB] Get: 11 http://deb.debian.org/debian unstable/main amd64 libkeyutils1 amd64 1.6.3-4 [9092 B] Get: 12 http://deb.debian.org/debian unstable/main amd64 libkrb5-3 amd64 1.21.3-3 [324 kB] Get: 13 http://deb.debian.org/debian unstable/main amd64 libgssapi-krb5-2 amd64 1.21.3-3 [136 kB] Get: 14 http://deb.debian.org/debian unstable/main amd64 libtirpc-common all 1.3.4+ds-1.3 [10.9 kB] Get: 15 http://deb.debian.org/debian unstable/main amd64 libtirpc3t64 amd64 1.3.4+ds-1.3+b1 [83.1 kB] Get: 16 http://deb.debian.org/debian unstable/main amd64 libnsl2 amd64 1.3.0-3+b3 [40.6 kB] Get: 17 http://deb.debian.org/debian unstable/main amd64 readline-common all 8.2-5 [69.3 kB] Get: 18 http://deb.debian.org/debian unstable/main amd64 libreadline8t64 amd64 8.2-5 [169 kB] Get: 19 http://deb.debian.org/debian unstable/main amd64 libpython3.12-stdlib amd64 3.12.7-3 [1966 kB] Get: 20 http://deb.debian.org/debian unstable/main amd64 python3.12 amd64 3.12.7-3 [671 kB] Get: 21 http://deb.debian.org/debian unstable/main amd64 libpython3-stdlib amd64 3.12.7-1 [9712 B] Get: 22 http://deb.debian.org/debian unstable/main amd64 python3 amd64 3.12.7-1 [27.8 kB] Get: 23 http://deb.debian.org/debian unstable/main amd64 libpython3.13-minimal amd64 3.13.0-2 [856 kB] Get: 24 http://deb.debian.org/debian unstable/main amd64 python3.13-minimal amd64 3.13.0-2 [2038 kB] Get: 25 http://deb.debian.org/debian unstable/main amd64 sensible-utils all 0.0.24 [24.8 kB] Get: 26 http://deb.debian.org/debian unstable/main amd64 libmagic-mgc amd64 1:5.45-3+b1 [314 kB] Get: 27 http://deb.debian.org/debian unstable/main amd64 libmagic1t64 amd64 1:5.45-3+b1 [108 kB] Get: 28 http://deb.debian.org/debian unstable/main amd64 file amd64 1:5.45-3+b1 [43.3 kB] Get: 29 http://deb.debian.org/debian unstable/main amd64 gettext-base amd64 0.22.5-2 [200 kB] Get: 30 http://deb.debian.org/debian unstable/main amd64 libuchardet0 amd64 0.0.8-1+b2 [68.9 kB] Get: 31 http://deb.debian.org/debian unstable/main amd64 groff-base amd64 1.23.0-5 [1181 kB] Get: 32 http://deb.debian.org/debian unstable/main amd64 bsdextrautils amd64 2.40.2-11 [91.5 kB] Get: 33 http://deb.debian.org/debian unstable/main amd64 libpipeline1 amd64 1.5.8-1 [42.0 kB] Get: 34 http://deb.debian.org/debian unstable/main amd64 man-db amd64 2.13.0-1 [1420 kB] Get: 35 http://deb.debian.org/debian unstable/main amd64 libantlr4-runtime4.9 amd64 4.9+dfsg-3+b2 [355 kB] Get: 36 http://deb.debian.org/debian unstable/main amd64 libicu72 amd64 72.1-5+b1 [9423 kB] Get: 37 http://deb.debian.org/debian unstable/main amd64 libxml2 amd64 2.12.7+dfsg+really2.9.14-0.2+b1 [699 kB] Get: 38 http://deb.debian.org/debian unstable/main amd64 afdko-bin amd64 4.0.1+dfsg1-2 [1137 kB] Get: 39 http://deb.debian.org/debian unstable/main amd64 m4 amd64 1.4.19-4 [287 kB] Get: 40 http://deb.debian.org/debian unstable/main amd64 autoconf all 2.72-3 [493 kB] Get: 41 http://deb.debian.org/debian unstable/main amd64 autotools-dev all 20220109.1 [51.6 kB] Get: 42 http://deb.debian.org/debian unstable/main amd64 automake all 1:1.16.5-1.3 [823 kB] Get: 43 http://deb.debian.org/debian unstable/main amd64 autopoint all 0.22.5-2 [723 kB] Get: 44 http://deb.debian.org/debian unstable/main amd64 libdebhelper-perl all 13.20 [89.7 kB] Get: 45 http://deb.debian.org/debian unstable/main amd64 libtool all 2.4.7-8 [517 kB] Get: 46 http://deb.debian.org/debian unstable/main amd64 dh-autoreconf all 20 [17.1 kB] Get: 47 http://deb.debian.org/debian unstable/main amd64 libarchive-zip-perl all 1.68-1 [104 kB] Get: 48 http://deb.debian.org/debian unstable/main amd64 libfile-stripnondeterminism-perl all 1.14.0-1 [19.5 kB] Get: 49 http://deb.debian.org/debian unstable/main amd64 dh-strip-nondeterminism all 1.14.0-1 [8448 B] Get: 50 http://deb.debian.org/debian unstable/main amd64 libelf1t64 amd64 0.192-4 [189 kB] Get: 51 http://deb.debian.org/debian unstable/main amd64 dwz amd64 0.15-1+b1 [110 kB] Get: 52 http://deb.debian.org/debian unstable/main amd64 gettext amd64 0.22.5-2 [1601 kB] Get: 53 http://deb.debian.org/debian unstable/main amd64 intltool-debian all 0.35.0+20060710.6 [22.9 kB] Get: 54 http://deb.debian.org/debian unstable/main amd64 po-debconf all 1.0.21+nmu1 [248 kB] Get: 55 http://deb.debian.org/debian unstable/main amd64 debhelper all 13.20 [915 kB] Get: 56 http://deb.debian.org/debian unstable/main amd64 python3-autocommand all 2.2.2-3 [13.6 kB] Get: 57 http://deb.debian.org/debian unstable/main amd64 python3-more-itertools all 10.5.0-1 [63.8 kB] Get: 58 http://deb.debian.org/debian unstable/main amd64 python3-typing-extensions all 4.12.2-2 [73.0 kB] Get: 59 http://deb.debian.org/debian unstable/main amd64 python3-typeguard all 4.4.1-1 [37.0 kB] Get: 60 http://deb.debian.org/debian unstable/main amd64 python3-inflect all 7.3.1-2 [32.4 kB] Get: 61 http://deb.debian.org/debian unstable/main amd64 python3-jaraco.context all 6.0.0-1 [7984 B] Get: 62 http://deb.debian.org/debian unstable/main amd64 python3-jaraco.functools all 4.1.0-1 [12.0 kB] Get: 63 http://deb.debian.org/debian unstable/main amd64 python3-pkg-resources all 75.2.0-1 [213 kB] Get: 64 http://deb.debian.org/debian unstable/main amd64 python3-jaraco.text all 4.0.0-1 [11.4 kB] Get: 65 http://deb.debian.org/debian unstable/main amd64 python3-zipp all 3.21.0-1 [10.6 kB] Get: 66 http://deb.debian.org/debian unstable/main amd64 python3-setuptools all 75.2.0-1 [731 kB] Get: 67 http://deb.debian.org/debian unstable/main amd64 dh-python all 6.20241024 [109 kB] Get: 68 http://deb.debian.org/debian unstable/main amd64 libblas3 amd64 3.12.0-4 [152 kB] Get: 69 http://deb.debian.org/debian unstable/main amd64 libgfortran5 amd64 14.2.0-8 [836 kB] Get: 70 http://deb.debian.org/debian unstable/main amd64 libjs-jquery all 3.6.1+dfsg+~3.5.14-1 [326 kB] Get: 71 http://deb.debian.org/debian unstable/main amd64 libjs-underscore all 1.13.4~dfsg+~1.11.4-3 [116 kB] Get: 72 http://deb.debian.org/debian unstable/main amd64 libjs-sphinxdoc all 7.4.7-4 [158 kB] Get: 73 http://deb.debian.org/debian unstable/main amd64 liblapack3 amd64 3.12.0-4 [2450 kB] Get: 74 http://deb.debian.org/debian unstable/main amd64 liblbfgsb0 amd64 3.0+dfsg.4-1+b2 [29.4 kB] Get: 75 http://deb.debian.org/debian unstable/main amd64 libpython3.13-stdlib amd64 3.13.0-2 [1992 kB] Get: 76 http://deb.debian.org/debian unstable/main amd64 libxslt1.1 amd64 1.1.35-1.1+b1 [233 kB] Get: 77 http://deb.debian.org/debian unstable/main amd64 python3.13 amd64 3.13.0-2 [730 kB] Get: 78 http://deb.debian.org/debian unstable/main amd64 python3-all amd64 3.12.7-1 [1052 B] Get: 79 http://deb.debian.org/debian unstable/main amd64 python3-appdirs all 1.4.4-4 [12.5 kB] Get: 80 http://deb.debian.org/debian unstable/main amd64 python3-attr all 24.2.0-1 [68.4 kB] Get: 81 http://deb.debian.org/debian unstable/main amd64 python3-brotli amd64 1.1.0-2+b6 [321 kB] Get: 82 http://deb.debian.org/debian unstable/main amd64 python3-tz all 2024.1-2 [30.9 kB] Get: 83 http://deb.debian.org/debian unstable/main amd64 python3-six all 1.16.0-7 [16.4 kB] Get: 84 http://deb.debian.org/debian unstable/main amd64 python3-fs all 2.4.16-4 [95.4 kB] Get: 85 http://deb.debian.org/debian unstable/main amd64 python3-lxml amd64 5.3.0-1+b1 [1676 kB] Get: 86 http://deb.debian.org/debian unstable/main amd64 python3-lz4 amd64 4.0.2+dfsg-1+b5 [25.6 kB] Get: 87 http://deb.debian.org/debian unstable/main amd64 python3-decorator all 5.1.1-5 [15.1 kB] Get: 88 http://deb.debian.org/debian unstable/main amd64 python3-numpy amd64 1:1.26.4+ds-12 [4738 kB] Get: 89 http://deb.debian.org/debian unstable/main amd64 python3-scipy amd64 1.14.1-2 [20.5 MB] Get: 90 http://deb.debian.org/debian unstable/main amd64 python3-mpmath all 1.3.0-1 [419 kB] Get: 91 http://deb.debian.org/debian unstable/main amd64 python3-sympy all 1.13.3-1 [4147 kB] Get: 92 http://deb.debian.org/debian unstable/main amd64 python3-ufolib2 all 0.16.1+dfsg1-1 [32.9 kB] Get: 93 http://deb.debian.org/debian unstable/main amd64 python3-defcon all 0.10.3-3 [189 kB] Get: 94 http://deb.debian.org/debian unstable/main amd64 unicode-data all 15.1.0-1 [8547 kB] Get: 95 http://deb.debian.org/debian unstable/main amd64 python3-fonttools amd64 4.55.0-3 [1634 kB] Get: 96 http://deb.debian.org/debian unstable/main amd64 python3-pyclipper amd64 1.3.0.post6-1+b1 [144 kB] Get: 97 http://deb.debian.org/debian unstable/main amd64 python3-booleanoperations all 0.9.0-3 [18.3 kB] Get: 98 http://deb.debian.org/debian unstable/main amd64 python3-cffsubr all 0.3.0-1 [9400 B] Get: 99 http://deb.debian.org/debian unstable/main amd64 python3-compreffor amd64 0.5.6-1+b1 [71.9 kB] Get: 100 http://deb.debian.org/debian unstable/main amd64 python3-fontmath all 0.9.4-1 [25.9 kB] Get: 101 http://deb.debian.org/debian unstable/main amd64 python3-iniconfig all 1.1.1-2 [6396 B] Get: 102 http://deb.debian.org/debian unstable/main amd64 python3-packaging all 24.2-1 [55.3 kB] Get: 103 http://deb.debian.org/debian unstable/main amd64 python3-pluggy all 1.5.0-1 [26.9 kB] Get: 104 http://deb.debian.org/debian unstable/main amd64 python3-pytest all 8.3.3-1 [249 kB] Get: 105 http://deb.debian.org/debian unstable/main amd64 python3-setuptools-scm all 8.1.0-1 [40.5 kB] Get: 106 http://deb.debian.org/debian unstable/main amd64 python3-syrupy all 4.7.2-1 [53.0 kB] Fetched 82.8 MB in 7s (12.6 MB/s) debconf: delaying package configuration, since apt-utils is not installed Selecting previously unselected package libpython3.12-minimal:amd64. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 19966 files and directories currently installed.) Preparing to unpack .../libpython3.12-minimal_3.12.7-3_amd64.deb ... Unpacking libpython3.12-minimal:amd64 (3.12.7-3) ... Selecting previously unselected package libexpat1:amd64. Preparing to unpack .../libexpat1_2.6.4-1_amd64.deb ... Unpacking libexpat1:amd64 (2.6.4-1) ... Selecting previously unselected package python3.12-minimal. Preparing to unpack .../python3.12-minimal_3.12.7-3_amd64.deb ... Unpacking python3.12-minimal (3.12.7-3) ... Setting up libpython3.12-minimal:amd64 (3.12.7-3) ... Setting up libexpat1:amd64 (2.6.4-1) ... Setting up python3.12-minimal (3.12.7-3) ... Selecting previously unselected package python3-minimal. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 20286 files and directories currently installed.) Preparing to unpack .../00-python3-minimal_3.12.7-1_amd64.deb ... Unpacking python3-minimal (3.12.7-1) ... Selecting previously unselected package media-types. Preparing to unpack .../01-media-types_10.1.0_all.deb ... Unpacking media-types (10.1.0) ... Selecting previously unselected package netbase. Preparing to unpack .../02-netbase_6.4_all.deb ... Unpacking netbase (6.4) ... Selecting previously unselected package tzdata. Preparing to unpack .../03-tzdata_2024b-3_all.deb ... Unpacking tzdata (2024b-3) ... Selecting previously unselected package libkrb5support0:amd64. Preparing to unpack .../04-libkrb5support0_1.21.3-3_amd64.deb ... Unpacking libkrb5support0:amd64 (1.21.3-3) ... Selecting previously unselected package libcom-err2:amd64. Preparing to unpack .../05-libcom-err2_1.47.1-1+b1_amd64.deb ... Unpacking libcom-err2:amd64 (1.47.1-1+b1) ... Selecting previously unselected package libk5crypto3:amd64. Preparing to unpack .../06-libk5crypto3_1.21.3-3_amd64.deb ... Unpacking libk5crypto3:amd64 (1.21.3-3) ... Selecting previously unselected package libkeyutils1:amd64. Preparing to unpack .../07-libkeyutils1_1.6.3-4_amd64.deb ... Unpacking libkeyutils1:amd64 (1.6.3-4) ... Selecting previously unselected package libkrb5-3:amd64. Preparing to unpack .../08-libkrb5-3_1.21.3-3_amd64.deb ... Unpacking libkrb5-3:amd64 (1.21.3-3) ... Selecting previously unselected package libgssapi-krb5-2:amd64. Preparing to unpack .../09-libgssapi-krb5-2_1.21.3-3_amd64.deb ... Unpacking libgssapi-krb5-2:amd64 (1.21.3-3) ... Selecting previously unselected package libtirpc-common. Preparing to unpack .../10-libtirpc-common_1.3.4+ds-1.3_all.deb ... Unpacking libtirpc-common (1.3.4+ds-1.3) ... Selecting previously unselected package libtirpc3t64:amd64. Preparing to unpack .../11-libtirpc3t64_1.3.4+ds-1.3+b1_amd64.deb ... Adding 'diversion of /lib/x86_64-linux-gnu/libtirpc.so.3 to /lib/x86_64-linux-gnu/libtirpc.so.3.usr-is-merged by libtirpc3t64' Adding 'diversion of /lib/x86_64-linux-gnu/libtirpc.so.3.0.0 to /lib/x86_64-linux-gnu/libtirpc.so.3.0.0.usr-is-merged by libtirpc3t64' Unpacking libtirpc3t64:amd64 (1.3.4+ds-1.3+b1) ... Selecting previously unselected package libnsl2:amd64. Preparing to unpack .../12-libnsl2_1.3.0-3+b3_amd64.deb ... Unpacking libnsl2:amd64 (1.3.0-3+b3) ... Selecting previously unselected package readline-common. Preparing to unpack .../13-readline-common_8.2-5_all.deb ... Unpacking readline-common (8.2-5) ... Selecting previously unselected package libreadline8t64:amd64. Preparing to unpack .../14-libreadline8t64_8.2-5_amd64.deb ... Adding 'diversion of /lib/x86_64-linux-gnu/libhistory.so.8 to /lib/x86_64-linux-gnu/libhistory.so.8.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/x86_64-linux-gnu/libhistory.so.8.2 to /lib/x86_64-linux-gnu/libhistory.so.8.2.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/x86_64-linux-gnu/libreadline.so.8 to /lib/x86_64-linux-gnu/libreadline.so.8.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/x86_64-linux-gnu/libreadline.so.8.2 to /lib/x86_64-linux-gnu/libreadline.so.8.2.usr-is-merged by libreadline8t64' Unpacking libreadline8t64:amd64 (8.2-5) ... Selecting previously unselected package libpython3.12-stdlib:amd64. Preparing to unpack .../15-libpython3.12-stdlib_3.12.7-3_amd64.deb ... Unpacking libpython3.12-stdlib:amd64 (3.12.7-3) ... Selecting previously unselected package python3.12. Preparing to unpack .../16-python3.12_3.12.7-3_amd64.deb ... Unpacking python3.12 (3.12.7-3) ... Selecting previously unselected package libpython3-stdlib:amd64. Preparing to unpack .../17-libpython3-stdlib_3.12.7-1_amd64.deb ... Unpacking libpython3-stdlib:amd64 (3.12.7-1) ... Setting up python3-minimal (3.12.7-1) ... Selecting previously unselected package python3. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 21348 files and directories currently installed.) Preparing to unpack .../00-python3_3.12.7-1_amd64.deb ... Unpacking python3 (3.12.7-1) ... Selecting previously unselected package libpython3.13-minimal:amd64. Preparing to unpack .../01-libpython3.13-minimal_3.13.0-2_amd64.deb ... Unpacking libpython3.13-minimal:amd64 (3.13.0-2) ... Selecting previously unselected package python3.13-minimal. Preparing to unpack .../02-python3.13-minimal_3.13.0-2_amd64.deb ... Unpacking python3.13-minimal (3.13.0-2) ... Selecting previously unselected package sensible-utils. Preparing to unpack .../03-sensible-utils_0.0.24_all.deb ... Unpacking sensible-utils (0.0.24) ... Selecting previously unselected package libmagic-mgc. Preparing to unpack .../04-libmagic-mgc_1%3a5.45-3+b1_amd64.deb ... Unpacking libmagic-mgc (1:5.45-3+b1) ... Selecting previously unselected package libmagic1t64:amd64. Preparing to unpack .../05-libmagic1t64_1%3a5.45-3+b1_amd64.deb ... Unpacking libmagic1t64:amd64 (1:5.45-3+b1) ... Selecting previously unselected package file. Preparing to unpack .../06-file_1%3a5.45-3+b1_amd64.deb ... Unpacking file (1:5.45-3+b1) ... Selecting previously unselected package gettext-base. Preparing to unpack .../07-gettext-base_0.22.5-2_amd64.deb ... Unpacking gettext-base (0.22.5-2) ... Selecting previously unselected package libuchardet0:amd64. Preparing to unpack .../08-libuchardet0_0.0.8-1+b2_amd64.deb ... Unpacking libuchardet0:amd64 (0.0.8-1+b2) ... Selecting previously unselected package groff-base. Preparing to unpack .../09-groff-base_1.23.0-5_amd64.deb ... Unpacking groff-base (1.23.0-5) ... Selecting previously unselected package bsdextrautils. Preparing to unpack .../10-bsdextrautils_2.40.2-11_amd64.deb ... Unpacking bsdextrautils (2.40.2-11) ... Selecting previously unselected package libpipeline1:amd64. Preparing to unpack .../11-libpipeline1_1.5.8-1_amd64.deb ... Unpacking libpipeline1:amd64 (1.5.8-1) ... Selecting previously unselected package man-db. Preparing to unpack .../12-man-db_2.13.0-1_amd64.deb ... Unpacking man-db (2.13.0-1) ... Selecting previously unselected package libantlr4-runtime4.9:amd64. Preparing to unpack .../13-libantlr4-runtime4.9_4.9+dfsg-3+b2_amd64.deb ... Unpacking libantlr4-runtime4.9:amd64 (4.9+dfsg-3+b2) ... Selecting previously unselected package libicu72:amd64. Preparing to unpack .../14-libicu72_72.1-5+b1_amd64.deb ... Unpacking libicu72:amd64 (72.1-5+b1) ... Selecting previously unselected package libxml2:amd64. Preparing to unpack .../15-libxml2_2.12.7+dfsg+really2.9.14-0.2+b1_amd64.deb ... Unpacking libxml2:amd64 (2.12.7+dfsg+really2.9.14-0.2+b1) ... Selecting previously unselected package afdko-bin. Preparing to unpack .../16-afdko-bin_4.0.1+dfsg1-2_amd64.deb ... Unpacking afdko-bin (4.0.1+dfsg1-2) ... Selecting previously unselected package m4. Preparing to unpack .../17-m4_1.4.19-4_amd64.deb ... Unpacking m4 (1.4.19-4) ... Selecting previously unselected package autoconf. Preparing to unpack .../18-autoconf_2.72-3_all.deb ... Unpacking autoconf (2.72-3) ... Selecting previously unselected package autotools-dev. Preparing to unpack .../19-autotools-dev_20220109.1_all.deb ... Unpacking autotools-dev (20220109.1) ... Selecting previously unselected package automake. Preparing to unpack .../20-automake_1%3a1.16.5-1.3_all.deb ... Unpacking automake (1:1.16.5-1.3) ... Selecting previously unselected package autopoint. Preparing to unpack .../21-autopoint_0.22.5-2_all.deb ... Unpacking autopoint (0.22.5-2) ... Selecting previously unselected package libdebhelper-perl. Preparing to unpack .../22-libdebhelper-perl_13.20_all.deb ... Unpacking libdebhelper-perl (13.20) ... Selecting previously unselected package libtool. Preparing to unpack .../23-libtool_2.4.7-8_all.deb ... Unpacking libtool (2.4.7-8) ... Selecting previously unselected package dh-autoreconf. Preparing to unpack .../24-dh-autoreconf_20_all.deb ... Unpacking dh-autoreconf (20) ... Selecting previously unselected package libarchive-zip-perl. Preparing to unpack .../25-libarchive-zip-perl_1.68-1_all.deb ... Unpacking libarchive-zip-perl (1.68-1) ... Selecting previously unselected package libfile-stripnondeterminism-perl. Preparing to unpack .../26-libfile-stripnondeterminism-perl_1.14.0-1_all.deb ... Unpacking libfile-stripnondeterminism-perl (1.14.0-1) ... Selecting previously unselected package dh-strip-nondeterminism. Preparing to unpack .../27-dh-strip-nondeterminism_1.14.0-1_all.deb ... Unpacking dh-strip-nondeterminism (1.14.0-1) ... Selecting previously unselected package libelf1t64:amd64. Preparing to unpack .../28-libelf1t64_0.192-4_amd64.deb ... Unpacking libelf1t64:amd64 (0.192-4) ... Selecting previously unselected package dwz. Preparing to unpack .../29-dwz_0.15-1+b1_amd64.deb ... Unpacking dwz (0.15-1+b1) ... Selecting previously unselected package gettext. Preparing to unpack .../30-gettext_0.22.5-2_amd64.deb ... Unpacking gettext (0.22.5-2) ... Selecting previously unselected package intltool-debian. Preparing to unpack .../31-intltool-debian_0.35.0+20060710.6_all.deb ... Unpacking intltool-debian (0.35.0+20060710.6) ... Selecting previously unselected package po-debconf. Preparing to unpack .../32-po-debconf_1.0.21+nmu1_all.deb ... Unpacking po-debconf (1.0.21+nmu1) ... Selecting previously unselected package debhelper. Preparing to unpack .../33-debhelper_13.20_all.deb ... Unpacking debhelper (13.20) ... Selecting previously unselected package python3-autocommand. Preparing to unpack .../34-python3-autocommand_2.2.2-3_all.deb ... Unpacking python3-autocommand (2.2.2-3) ... Selecting previously unselected package python3-more-itertools. Preparing to unpack .../35-python3-more-itertools_10.5.0-1_all.deb ... Unpacking python3-more-itertools (10.5.0-1) ... Selecting previously unselected package python3-typing-extensions. Preparing to unpack .../36-python3-typing-extensions_4.12.2-2_all.deb ... Unpacking python3-typing-extensions (4.12.2-2) ... Selecting previously unselected package python3-typeguard. Preparing to unpack .../37-python3-typeguard_4.4.1-1_all.deb ... Unpacking python3-typeguard (4.4.1-1) ... Selecting previously unselected package python3-inflect. Preparing to unpack .../38-python3-inflect_7.3.1-2_all.deb ... Unpacking python3-inflect (7.3.1-2) ... Selecting previously unselected package python3-jaraco.context. Preparing to unpack .../39-python3-jaraco.context_6.0.0-1_all.deb ... Unpacking python3-jaraco.context (6.0.0-1) ... Selecting previously unselected package python3-jaraco.functools. Preparing to unpack .../40-python3-jaraco.functools_4.1.0-1_all.deb ... Unpacking python3-jaraco.functools (4.1.0-1) ... Selecting previously unselected package python3-pkg-resources. Preparing to unpack .../41-python3-pkg-resources_75.2.0-1_all.deb ... Unpacking python3-pkg-resources (75.2.0-1) ... Selecting previously unselected package python3-jaraco.text. Preparing to unpack .../42-python3-jaraco.text_4.0.0-1_all.deb ... Unpacking python3-jaraco.text (4.0.0-1) ... Selecting previously unselected package python3-zipp. Preparing to unpack .../43-python3-zipp_3.21.0-1_all.deb ... Unpacking python3-zipp (3.21.0-1) ... Selecting previously unselected package python3-setuptools. Preparing to unpack .../44-python3-setuptools_75.2.0-1_all.deb ... Unpacking python3-setuptools (75.2.0-1) ... Selecting previously unselected package dh-python. Preparing to unpack .../45-dh-python_6.20241024_all.deb ... Unpacking dh-python (6.20241024) ... Selecting previously unselected package libblas3:amd64. Preparing to unpack .../46-libblas3_3.12.0-4_amd64.deb ... Unpacking libblas3:amd64 (3.12.0-4) ... Selecting previously unselected package libgfortran5:amd64. Preparing to unpack .../47-libgfortran5_14.2.0-8_amd64.deb ... Unpacking libgfortran5:amd64 (14.2.0-8) ... Selecting previously unselected package libjs-jquery. Preparing to unpack .../48-libjs-jquery_3.6.1+dfsg+~3.5.14-1_all.deb ... Unpacking libjs-jquery (3.6.1+dfsg+~3.5.14-1) ... Selecting previously unselected package libjs-underscore. Preparing to unpack .../49-libjs-underscore_1.13.4~dfsg+~1.11.4-3_all.deb ... Unpacking libjs-underscore (1.13.4~dfsg+~1.11.4-3) ... Selecting previously unselected package libjs-sphinxdoc. Preparing to unpack .../50-libjs-sphinxdoc_7.4.7-4_all.deb ... Unpacking libjs-sphinxdoc (7.4.7-4) ... Selecting previously unselected package liblapack3:amd64. Preparing to unpack .../51-liblapack3_3.12.0-4_amd64.deb ... Unpacking liblapack3:amd64 (3.12.0-4) ... Selecting previously unselected package liblbfgsb0:amd64. Preparing to unpack .../52-liblbfgsb0_3.0+dfsg.4-1+b2_amd64.deb ... Unpacking liblbfgsb0:amd64 (3.0+dfsg.4-1+b2) ... Selecting previously unselected package libpython3.13-stdlib:amd64. Preparing to unpack .../53-libpython3.13-stdlib_3.13.0-2_amd64.deb ... Unpacking libpython3.13-stdlib:amd64 (3.13.0-2) ... Selecting previously unselected package libxslt1.1:amd64. Preparing to unpack .../54-libxslt1.1_1.1.35-1.1+b1_amd64.deb ... Unpacking libxslt1.1:amd64 (1.1.35-1.1+b1) ... Selecting previously unselected package python3.13. Preparing to unpack .../55-python3.13_3.13.0-2_amd64.deb ... Unpacking python3.13 (3.13.0-2) ... Selecting previously unselected package python3-all. Preparing to unpack .../56-python3-all_3.12.7-1_amd64.deb ... Unpacking python3-all (3.12.7-1) ... Selecting previously unselected package python3-appdirs. Preparing to unpack .../57-python3-appdirs_1.4.4-4_all.deb ... Unpacking python3-appdirs (1.4.4-4) ... Selecting previously unselected package python3-attr. Preparing to unpack .../58-python3-attr_24.2.0-1_all.deb ... Unpacking python3-attr (24.2.0-1) ... Selecting previously unselected package python3-brotli. Preparing to unpack .../59-python3-brotli_1.1.0-2+b6_amd64.deb ... Unpacking python3-brotli (1.1.0-2+b6) ... Selecting previously unselected package python3-tz. Preparing to unpack .../60-python3-tz_2024.1-2_all.deb ... Unpacking python3-tz (2024.1-2) ... Selecting previously unselected package python3-six. Preparing to unpack .../61-python3-six_1.16.0-7_all.deb ... Unpacking python3-six (1.16.0-7) ... Selecting previously unselected package python3-fs. Preparing to unpack .../62-python3-fs_2.4.16-4_all.deb ... Unpacking python3-fs (2.4.16-4) ... Selecting previously unselected package python3-lxml:amd64. Preparing to unpack .../63-python3-lxml_5.3.0-1+b1_amd64.deb ... Unpacking python3-lxml:amd64 (5.3.0-1+b1) ... Selecting previously unselected package python3-lz4. Preparing to unpack .../64-python3-lz4_4.0.2+dfsg-1+b5_amd64.deb ... Unpacking python3-lz4 (4.0.2+dfsg-1+b5) ... Selecting previously unselected package python3-decorator. Preparing to unpack .../65-python3-decorator_5.1.1-5_all.deb ... Unpacking python3-decorator (5.1.1-5) ... Selecting previously unselected package python3-numpy. Preparing to unpack .../66-python3-numpy_1%3a1.26.4+ds-12_amd64.deb ... Unpacking python3-numpy (1:1.26.4+ds-12) ... Selecting previously unselected package python3-scipy. Preparing to unpack .../67-python3-scipy_1.14.1-2_amd64.deb ... Unpacking python3-scipy (1.14.1-2) ... Selecting previously unselected package python3-mpmath. Preparing to unpack .../68-python3-mpmath_1.3.0-1_all.deb ... Unpacking python3-mpmath (1.3.0-1) ... Selecting previously unselected package python3-sympy. Preparing to unpack .../69-python3-sympy_1.13.3-1_all.deb ... Unpacking python3-sympy (1.13.3-1) ... Selecting previously unselected package python3-ufolib2. Preparing to unpack .../70-python3-ufolib2_0.16.1+dfsg1-1_all.deb ... Unpacking python3-ufolib2 (0.16.1+dfsg1-1) ... Selecting previously unselected package python3-defcon. Preparing to unpack .../71-python3-defcon_0.10.3-3_all.deb ... Unpacking python3-defcon (0.10.3-3) ... Selecting previously unselected package unicode-data. Preparing to unpack .../72-unicode-data_15.1.0-1_all.deb ... Unpacking unicode-data (15.1.0-1) ... Selecting previously unselected package python3-fonttools. Preparing to unpack .../73-python3-fonttools_4.55.0-3_amd64.deb ... Unpacking python3-fonttools (4.55.0-3) ... Selecting previously unselected package python3-pyclipper. Preparing to unpack .../74-python3-pyclipper_1.3.0.post6-1+b1_amd64.deb ... Unpacking python3-pyclipper (1.3.0.post6-1+b1) ... Selecting previously unselected package python3-booleanoperations. Preparing to unpack .../75-python3-booleanoperations_0.9.0-3_all.deb ... Unpacking python3-booleanoperations (0.9.0-3) ... Selecting previously unselected package python3-cffsubr. Preparing to unpack .../76-python3-cffsubr_0.3.0-1_all.deb ... Unpacking python3-cffsubr (0.3.0-1) ... Selecting previously unselected package python3-compreffor. Preparing to unpack .../77-python3-compreffor_0.5.6-1+b1_amd64.deb ... Unpacking python3-compreffor (0.5.6-1+b1) ... Selecting previously unselected package python3-fontmath. Preparing to unpack .../78-python3-fontmath_0.9.4-1_all.deb ... Unpacking python3-fontmath (0.9.4-1) ... Selecting previously unselected package python3-iniconfig. Preparing to unpack .../79-python3-iniconfig_1.1.1-2_all.deb ... Unpacking python3-iniconfig (1.1.1-2) ... Selecting previously unselected package python3-packaging. Preparing to unpack .../80-python3-packaging_24.2-1_all.deb ... Unpacking python3-packaging (24.2-1) ... Selecting previously unselected package python3-pluggy. Preparing to unpack .../81-python3-pluggy_1.5.0-1_all.deb ... Unpacking python3-pluggy (1.5.0-1) ... Selecting previously unselected package python3-pytest. Preparing to unpack .../82-python3-pytest_8.3.3-1_all.deb ... Unpacking python3-pytest (8.3.3-1) ... Selecting previously unselected package python3-setuptools-scm. Preparing to unpack .../83-python3-setuptools-scm_8.1.0-1_all.deb ... Unpacking python3-setuptools-scm (8.1.0-1) ... Selecting previously unselected package python3-syrupy. Preparing to unpack .../84-python3-syrupy_4.7.2-1_all.deb ... Unpacking python3-syrupy (4.7.2-1) ... Setting up media-types (10.1.0) ... Setting up libpipeline1:amd64 (1.5.8-1) ... Setting up libkeyutils1:amd64 (1.6.3-4) ... Setting up libicu72:amd64 (72.1-5+b1) ... Setting up bsdextrautils (2.40.2-11) ... Setting up libmagic-mgc (1:5.45-3+b1) ... Setting up libantlr4-runtime4.9:amd64 (4.9+dfsg-3+b2) ... Setting up libarchive-zip-perl (1.68-1) ... Setting up libtirpc-common (1.3.4+ds-1.3) ... Setting up libdebhelper-perl (13.20) ... Setting up libmagic1t64:amd64 (1:5.45-3+b1) ... Setting up gettext-base (0.22.5-2) ... Setting up m4 (1.4.19-4) ... Setting up libcom-err2:amd64 (1.47.1-1+b1) ... Setting up file (1:5.45-3+b1) ... Setting up libelf1t64:amd64 (0.192-4) ... Setting up libkrb5support0:amd64 (1.21.3-3) ... Setting up tzdata (2024b-3) ... Current default time zone: 'Etc/UTC' Local time is now: Sun Dec 28 01:56:47 UTC 2025. Universal Time is now: Sun Dec 28 01:56:47 UTC 2025. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up unicode-data (15.1.0-1) ... Setting up libpython3.13-minimal:amd64 (3.13.0-2) ... Setting up autotools-dev (20220109.1) ... Setting up libblas3:amd64 (3.12.0-4) ... update-alternatives: using /usr/lib/x86_64-linux-gnu/blas/libblas.so.3 to provide /usr/lib/x86_64-linux-gnu/libblas.so.3 (libblas.so.3-x86_64-linux-gnu) in auto mode Setting up autopoint (0.22.5-2) ... Setting up libk5crypto3:amd64 (1.21.3-3) ... Setting up libgfortran5:amd64 (14.2.0-8) ... Setting up autoconf (2.72-3) ... Setting up dwz (0.15-1+b1) ... Setting up sensible-utils (0.0.24) ... Setting up libuchardet0:amd64 (0.0.8-1+b2) ... Setting up python3.13-minimal (3.13.0-2) ... Setting up netbase (6.4) ... Setting up libkrb5-3:amd64 (1.21.3-3) ... Setting up libjs-jquery (3.6.1+dfsg+~3.5.14-1) ... Setting up readline-common (8.2-5) ... Setting up libxml2:amd64 (2.12.7+dfsg+really2.9.14-0.2+b1) ... Setting up libjs-underscore (1.13.4~dfsg+~1.11.4-3) ... Setting up automake (1:1.16.5-1.3) ... update-alternatives: using /usr/bin/automake-1.16 to provide /usr/bin/automake (automake) in auto mode Setting up libfile-stripnondeterminism-perl (1.14.0-1) ... Setting up liblapack3:amd64 (3.12.0-4) ... update-alternatives: using /usr/lib/x86_64-linux-gnu/lapack/liblapack.so.3 to provide /usr/lib/x86_64-linux-gnu/liblapack.so.3 (liblapack.so.3-x86_64-linux-gnu) in auto mode Setting up gettext (0.22.5-2) ... Setting up libtool (2.4.7-8) ... Setting up intltool-debian (0.35.0+20060710.6) ... Setting up dh-autoreconf (20) ... Setting up libgssapi-krb5-2:amd64 (1.21.3-3) ... Setting up libjs-sphinxdoc (7.4.7-4) ... Setting up libreadline8t64:amd64 (8.2-5) ... Setting up dh-strip-nondeterminism (1.14.0-1) ... Setting up groff-base (1.23.0-5) ... Setting up libxslt1.1:amd64 (1.1.35-1.1+b1) ... Setting up afdko-bin (4.0.1+dfsg1-2) ... Setting up libpython3.13-stdlib:amd64 (3.13.0-2) ... Setting up liblbfgsb0:amd64 (3.0+dfsg.4-1+b2) ... Setting up libtirpc3t64:amd64 (1.3.4+ds-1.3+b1) ... Setting up python3.13 (3.13.0-2) ... Setting up po-debconf (1.0.21+nmu1) ... Setting up man-db (2.13.0-1) ... Not building database; man-db/auto-update is not 'true'. Setting up libnsl2:amd64 (1.3.0-3+b3) ... Setting up libpython3.12-stdlib:amd64 (3.12.7-3) ... Setting up python3.12 (3.12.7-3) ... Setting up debhelper (13.20) ... Setting up libpython3-stdlib:amd64 (3.12.7-1) ... Setting up python3 (3.12.7-1) ... Setting up python3-zipp (3.21.0-1) ... Setting up python3-autocommand (2.2.2-3) ... Setting up python3-tz (2024.1-2) ... Setting up python3-six (1.16.0-7) ... Setting up python3-decorator (5.1.1-5) ... Setting up python3-packaging (24.2-1) ... Setting up python3-brotli (1.1.0-2+b6) ... Setting up python3-typing-extensions (4.12.2-2) ... Setting up python3-pluggy (1.5.0-1) ... Setting up python3-lxml:amd64 (5.3.0-1+b1) ... Setting up python3-mpmath (1.3.0-1) ... Setting up python3-appdirs (1.4.4-4) ... Setting up python3-pyclipper (1.3.0.post6-1+b1) ... Setting up python3-more-itertools (10.5.0-1) ... Setting up python3-iniconfig (1.1.1-2) ... Setting up python3-sympy (1.13.3-1) ... Setting up python3-attr (24.2.0-1) ... Setting up python3-jaraco.functools (4.1.0-1) ... Setting up python3-jaraco.context (6.0.0-1) ... Setting up python3-lz4 (4.0.2+dfsg-1+b5) ... Setting up python3-pytest (8.3.3-1) ... Setting up python3-syrupy (4.7.2-1) ... Setting up python3-typeguard (4.4.1-1) ... Setting up python3-all (3.12.7-1) ... Setting up python3-inflect (7.3.1-2) ... Setting up python3-jaraco.text (4.0.0-1) ... Setting up python3-pkg-resources (75.2.0-1) ... Setting up python3-setuptools (75.2.0-1) ... Setting up python3-setuptools-scm (8.1.0-1) ... Setting up python3-fs (2.4.16-4) ... Setting up python3-numpy (1:1.26.4+ds-12) ... Setting up dh-python (6.20241024) ... Setting up python3-scipy (1.14.1-2) ... Setting up python3-defcon (0.10.3-3) ... Setting up python3-fonttools (4.55.0-3) ... Setting up python3-ufolib2 (0.16.1+dfsg1-1) ... Setting up python3-fontmath (0.9.4-1) ... Setting up python3-cffsubr (0.3.0-1) ... Setting up python3-booleanoperations (0.9.0-3) ... Setting up python3-compreffor (0.5.6-1+b1) ... Processing triggers for libc-bin (2.40-4) ... Reading package lists... Building dependency tree... Reading state information... Reading extended state information... Initializing package states... Writing extended state information... Building tag database... -> Finished parsing the build-deps Reading package lists... Building dependency tree... Reading state information... fakeroot is already the newest version (1.36-1). 0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. I: Building the package I: user script /srv/workspace/pbuilder/501244/tmp/hooks/A99_set_merged_usr starting Not re-configuring usrmerge for unstable I: user script /srv/workspace/pbuilder/501244/tmp/hooks/A99_set_merged_usr finished hostname: Name or service not known I: Running cd /build/reproducible-path/ufo2ft-3.3.1/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-genchanges -S > ../ufo2ft_3.3.1-2_source.changes dpkg-buildpackage: info: source package ufo2ft dpkg-buildpackage: info: source version 3.3.1-2 dpkg-buildpackage: info: source distribution unstable dpkg-buildpackage: info: source changed by Boyuan Yang dpkg-source --before-build . dpkg-buildpackage: info: host architecture amd64 fakeroot debian/rules clean dh clean --buildsystem=pybuild debian/rules override_dh_auto_clean make[1]: Entering directory '/build/reproducible-path/ufo2ft-3.3.1' dh_auto_clean I: pybuild base:311: python3.13 setup.py clean /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running clean removing '/build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build' (and everything under it) 'build/bdist.linux-x86_64' does not exist -- can't clean it 'build/scripts-3.13' does not exist -- can't clean it I: pybuild base:311: python3.12 setup.py clean /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running clean removing '/build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build' (and everything under it) 'build/bdist.linux-x86_64' does not exist -- can't clean it 'build/scripts-3.12' does not exist -- can't clean it rm Lib/ufo2ft/_version.py make[1]: Leaving directory '/build/reproducible-path/ufo2ft-3.3.1' dh_autoreconf_clean -O--buildsystem=pybuild dh_clean -O--buildsystem=pybuild debian/rules build dh build --buildsystem=pybuild dh_update_autotools_config -O--buildsystem=pybuild dh_autoreconf -O--buildsystem=pybuild dh_auto_configure -O--buildsystem=pybuild I: pybuild base:311: python3.13 setup.py config /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running config I: pybuild base:311: python3.12 setup.py config /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running config dh_auto_build -O--buildsystem=pybuild I: pybuild base:311: /usr/bin/python3.13 setup.py build /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running build running build_py creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers running egg_info creating Lib/ufo2ft.egg-info writing Lib/ufo2ft.egg-info/PKG-INFO writing dependency_links to Lib/ufo2ft.egg-info/dependency_links.txt writing requirements to Lib/ufo2ft.egg-info/requires.txt writing top-level names to Lib/ufo2ft.egg-info/top_level.txt writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' adding license file 'LICENSE' writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' I: pybuild base:311: /usr/bin/python3 setup.py build /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running build running build_py creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters copying Lib/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers copying Lib/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers running egg_info writing Lib/ufo2ft.egg-info/PKG-INFO writing dependency_links to Lib/ufo2ft.egg-info/dependency_links.txt writing requirements to Lib/ufo2ft.egg-info/requires.txt writing top-level names to Lib/ufo2ft.egg-info/top_level.txt reading manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' adding license file 'LICENSE' writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' debian/rules override_dh_auto_test make[1]: Entering directory '/build/reproducible-path/ufo2ft-3.3.1' # For experimental build, allow failures dh_auto_test I: pybuild base:311: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build; python3.13 -m pytest tests ============================= test session starts ============================== platform linux -- Python 3.13.0, pytest-8.3.3, pluggy-1.5.0 rootdir: /build/reproducible-path/ufo2ft-3.3.1 configfile: setup.cfg plugins: typeguard-4.4.1, syrupy-4.7.2 collected 1140 items tests/featureCompiler_test.py ................ [ 1%] tests/featureWriters/cursFeatureWriter_test.py ......... [ 2%] tests/featureWriters/featureWriters_test.py ........ [ 2%] tests/featureWriters/gdefFeatureWriter_test.py .......... [ 3%] tests/featureWriters/kernFeatureWriter2_test.py ........................ [ 5%] ....F..... [ 6%] tests/featureWriters/kernFeatureWriter_test.py ......................... [ 8%] ......F..... [ 10%] tests/featureWriters/markFeatureWriter_test.py ......................... [ 12%] ............ [ 13%] tests/featureWriters/variableFeatureWriter_test.py .. [ 13%] tests/filters/decomposeComponents_test.py ...... [ 13%] tests/filters/decomposeTransformedComponents_test.py ... [ 14%] tests/filters/dottedCircle_test.py ... [ 14%] tests/filters/explodeColorLayerGlyphs_test.py . [ 14%] tests/filters/flattenComponents_test.py ........ [ 15%] tests/filters/propagateAnchors_test.py ............... [ 16%] tests/filters/sortContours_test.py .... [ 16%] tests/filters/transformations_test.py ............................... [ 19%] tests/fontInfoData_test.py ................ [ 21%] tests/infoCompiler_test.py ....... [ 21%] tests/instantiator_test.py ........................... [ 24%] tests/instructionCompiler_test.py ...................................... [ 27%] ......... [ 28%] tests/integration_test.py ......s.s.............FFFFFFF...FF.....FF..... [ 32%] ..............FF. [ 33%] tests/outlineCompiler_test.py .......................................... [ 37%] ........................................................................ [ 43%] ........................ [ 45%] tests/preProcessor_test.py ....s......s.............. [ 48%] tests/util_test.py . [ 48%] tests/featureCompiler_test.py ................ [ 49%] tests/featureWriters/cursFeatureWriter_test.py ......... [ 50%] tests/featureWriters/featureWriters_test.py ........ [ 51%] tests/featureWriters/gdefFeatureWriter_test.py .......... [ 51%] tests/featureWriters/kernFeatureWriter2_test.py ........................ [ 54%] ....F..... [ 54%] tests/featureWriters/kernFeatureWriter_test.py ......................... [ 57%] ......F..... [ 58%] tests/featureWriters/markFeatureWriter_test.py ......................... [ 60%] ............ [ 61%] tests/featureWriters/variableFeatureWriter_test.py .. [ 61%] tests/filters/decomposeComponents_test.py ...... [ 62%] tests/filters/decomposeTransformedComponents_test.py ... [ 62%] tests/filters/dottedCircle_test.py ... [ 62%] tests/filters/explodeColorLayerGlyphs_test.py . [ 62%] tests/filters/flattenComponents_test.py ........ [ 63%] tests/filters/propagateAnchors_test.py ............... [ 64%] tests/filters/sortContours_test.py .... [ 65%] tests/filters/transformations_test.py ............................... [ 67%] tests/fontInfoData_test.py ................ [ 69%] tests/infoCompiler_test.py ....... [ 69%] tests/instantiator_test.py ........................... [ 72%] tests/instructionCompiler_test.py ...................................... [ 75%] ......... [ 76%] tests/integration_test.py ......s.s.............FFFFFFF...FF.....FF..... [ 80%] ..............FF. [ 81%] tests/outlineCompiler_test.py .......................................... [ 85%] ........................................................................ [ 91%] ........................ [ 93%] tests/preProcessor_test.py ....s......s.............. [ 96%] tests/util_test.py . [ 96%] tests/featureWriters/ast_test.py . [ 96%] tests/featureWriters/markFeatureWriter_test.py ......... [ 97%] tests/filters/filters_test.py ................... [ 98%] tests/filters/transformations_test.py . [ 98%] tests/fontInfoData_test.py .. [ 99%] tests/instantiator_test.py .... [ 99%] tests/instructionCompiler_test.py .... [ 99%] tests/util_test.py .. [100%] =================================== FAILURES =================================== _________________________ test_kern_zyyy_zinh[defcon] __________________________ snapshot = ''' lookup kern_dflt { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni0310 uni0310 1; pos uni03...a; language dflt; lookup kern_dflt; script dupl; language dflt; lookup kern_dflt; } dist; ''' FontClass = def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert newFeatures.asFea() == snapshot E AssertionError: assert [+ received] == [- snapshot] E ''' E ... E lookupflag IgnoreMarks; E - pos uni0300 uni0300 0; E - pos uni0310 uni0310 1; E - pos uni0320 uni0320 2; E - pos uni0330 uni0330 3;... E E ...Full output truncated (85 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[defcon] __________________________ FontClass = def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert dedent(str(newFeatures)) == dedent( """\ lookup kern_Deva { lookupflag IgnoreMarks; pos uni1CD0 uni1CD0 7; pos uni1CE0 uni1CE0 8; pos uni1CF0 uni1CF0 9; pos uni20F0 uni20F0 11; pos uniA830 uniA830 34; } kern_Deva; lookup kern_Dupl { lookupflag IgnoreMarks; pos uni1BCA0 uni1BCA0 42; } kern_Dupl; lookup kern_Grek { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni1DC0 uni1DC0 10; } kern_Grek; lookup kern_Hani_Hrkt { lookupflag IgnoreMarks; pos uni1D360 uni1D360 43; pos uni1D370 uni1D370 44; pos uni1F250 uni1F250 45; pos uni2FF0 uni2FF0 13; pos uni3010 uni3010 14; pos uni3030 uni3030 15; pos uni30A0 uni30A0 16; pos uni3190 uni3190 17; pos uni31C0 uni31C0 18; pos uni31D0 uni31D0 19; pos uni31E0 uni31E0 20; pos uni3220 uni3220 21; pos uni3230 uni3230 22; pos uni3240 uni3240 23; pos uni3280 uni3280 24; pos uni3290 uni3290 25; pos uni32A0 uni32A0 26; pos uni32B0 uni32B0 27; pos uni32C0 uni32C0 28; pos uni3360 uni3360 29; pos uni3370 uni3370 30; pos uni33E0 uni33E0 31; pos uni33F0 uni33F0 32; pos uniA700 uniA700 33; pos uniFF70 uniFF70 35; } kern_Hani_Hrkt; lookup kern_Default { lookupflag IgnoreMarks; pos uni0310 uni0310 1; pos uni0320 uni0320 2; pos uni0330 uni0330 3; pos uni0640 uni0640 4; pos uni0650 uni0650 5; pos uni0670 uni0670 6; pos uni10100 uni10100 36; pos uni10110 uni10110 37; pos uni10120 uni10120 38; pos uni10130 uni10130 39; pos uni102E0 uni102E0 40; pos uni102F0 uni102F0 41; pos uni2E30 uni2E30 12; } kern_Default; feature kern { script DFLT; language dflt; lookup kern_Default; lookup kern_Grek; lookup kern_Hani_Hrkt; script grek; language dflt; lookup kern_Default; lookup kern_Grek; script hani; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; script kana; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; } kern; feature dist { script dev2; language dflt; lookup kern_Default; lookup kern_Deva; script deva; language dflt; lookup kern_Default; lookup kern_Deva; script dupl; language dflt; lookup kern_Default; lookup kern_Dupl; } dist; """ ) E AssertionError: assert 'lookup kern_...l;\n} dist;\n' == 'lookup kern_...l;\n} dist;\n' E E Skipping 61 identical leading characters in diff, use -v to show E - 0 uni1CD0 7; E ? ^ E + 0 uni1CD0 3; E ? ^ E - pos uni1CE0 uni1CE0 8;... E E ...Full output truncated (218 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError _____________ IntegrationTest.test_compileVariableTTF[defcon-None] _____________ self = designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _____________ IntegrationTest.test_compileVariableTTF[defcon-True] _____________ self = designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-useProductionNames.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[defcon-False] _____________ self = designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-None] _____________ self = designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-True] _____________ self = designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-useProductionNames.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-False] ____________ self = designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ________ IntegrationTest.test_compileVariableCFF2_subroutinized[defcon] ________ self = designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) > expectTTX(varfont, "TestVariableFont-CFF2-cffsubr.ttx") tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-cffsubr.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ self = designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-post3.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ self = designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-post3.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _______________ IntegrationTest.test_compileVariableTTFs[defcon] _______________ self = designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-TTF.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-TTF.ttx", ) tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-TTF.ttx +++ @@ -251,99 +251,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -417,42 +324,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -635,17 +539,17 @@ - + - + - + @@ -654,7 +558,7 @@ - + @@ -671,7 +575,7 @@ - + @@ -688,13 +592,13 @@ - + - + @@ -702,7 +606,7 @@ - + @@ -710,7 +614,7 @@ - + @@ -718,7 +622,7 @@ - + @@ -726,7 +630,7 @@ - + @@ -734,13 +638,13 @@ - + - + ______________ IntegrationTest.test_compileVariableCFF2s[defcon] _______________ self = designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-CFF2.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx", ) tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx +++ @@ -128,99 +128,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -294,42 +201,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -692,17 +596,17 @@ - + - + - + @@ -711,7 +615,7 @@ - + @@ -728,7 +632,7 @@ - + @@ -745,13 +649,13 @@ - + - + @@ -759,7 +663,7 @@ - + @@ -767,7 +671,7 @@ - + @@ -775,7 +679,7 @@ - + @@ -783,7 +687,7 @@ - + @@ -791,13 +695,13 @@ - + - + _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableTTFs] ______ self = FontClass = compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableCFF2s] _____ self = FontClass = compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ snapshot = ''' lookup kern_dflt { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni0310 uni0310 1; pos uni03...a; language dflt; lookup kern_dflt; script dupl; language dflt; lookup kern_dflt; } dist; ''' FontClass = .ctor at 0x7fdac8861620> def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert newFeatures.asFea() == snapshot E AssertionError: assert [+ received] == [- snapshot] E ''' E ... E lookupflag IgnoreMarks; E - pos uni0300 uni0300 0; E - pos uni0310 uni0310 1; E - pos uni0320 uni0320 2; E - pos uni0330 uni0330 3;... E E ...Full output truncated (85 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ FontClass = .ctor at 0x7fdac8861620> def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert dedent(str(newFeatures)) == dedent( """\ lookup kern_Deva { lookupflag IgnoreMarks; pos uni1CD0 uni1CD0 7; pos uni1CE0 uni1CE0 8; pos uni1CF0 uni1CF0 9; pos uni20F0 uni20F0 11; pos uniA830 uniA830 34; } kern_Deva; lookup kern_Dupl { lookupflag IgnoreMarks; pos uni1BCA0 uni1BCA0 42; } kern_Dupl; lookup kern_Grek { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni1DC0 uni1DC0 10; } kern_Grek; lookup kern_Hani_Hrkt { lookupflag IgnoreMarks; pos uni1D360 uni1D360 43; pos uni1D370 uni1D370 44; pos uni1F250 uni1F250 45; pos uni2FF0 uni2FF0 13; pos uni3010 uni3010 14; pos uni3030 uni3030 15; pos uni30A0 uni30A0 16; pos uni3190 uni3190 17; pos uni31C0 uni31C0 18; pos uni31D0 uni31D0 19; pos uni31E0 uni31E0 20; pos uni3220 uni3220 21; pos uni3230 uni3230 22; pos uni3240 uni3240 23; pos uni3280 uni3280 24; pos uni3290 uni3290 25; pos uni32A0 uni32A0 26; pos uni32B0 uni32B0 27; pos uni32C0 uni32C0 28; pos uni3360 uni3360 29; pos uni3370 uni3370 30; pos uni33E0 uni33E0 31; pos uni33F0 uni33F0 32; pos uniA700 uniA700 33; pos uniFF70 uniFF70 35; } kern_Hani_Hrkt; lookup kern_Default { lookupflag IgnoreMarks; pos uni0310 uni0310 1; pos uni0320 uni0320 2; pos uni0330 uni0330 3; pos uni0640 uni0640 4; pos uni0650 uni0650 5; pos uni0670 uni0670 6; pos uni10100 uni10100 36; pos uni10110 uni10110 37; pos uni10120 uni10120 38; pos uni10130 uni10130 39; pos uni102E0 uni102E0 40; pos uni102F0 uni102F0 41; pos uni2E30 uni2E30 12; } kern_Default; feature kern { script DFLT; language dflt; lookup kern_Default; lookup kern_Grek; lookup kern_Hani_Hrkt; script grek; language dflt; lookup kern_Default; lookup kern_Grek; script hani; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; script kana; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; } kern; feature dist { script dev2; language dflt; lookup kern_Default; lookup kern_Deva; script deva; language dflt; lookup kern_Default; lookup kern_Deva; script dupl; language dflt; lookup kern_Default; lookup kern_Dupl; } dist; """ ) E AssertionError: assert 'lookup kern_...l;\n} dist;\n' == 'lookup kern_...l;\n} dist;\n' E E Skipping 61 identical leading characters in diff, use -v to show E - 0 uni1CD0 7; E ? ^ E + 0 uni1CD0 3; E ? ^ E - pos uni1CE0 uni1CE0 8;... E E ...Full output truncated (218 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-None] _____________ self = designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-True] _____________ self = designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-useProductionNames.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-False] ____________ self = designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-None] ____________ self = designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-True] ____________ self = designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-useProductionNames.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ___________ IntegrationTest.test_compileVariableCFF2[ufoLib2-False] ____________ self = designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _______ IntegrationTest.test_compileVariableCFF2_subroutinized[ufoLib2] ________ self = designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) > expectTTX(varfont, "TestVariableFont-CFF2-cffsubr.ttx") tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-cffsubr.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ self = designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-post3.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ self = designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-post3.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ______________ IntegrationTest.test_compileVariableTTFs[ufoLib2] _______________ self = designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-TTF.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-TTF.ttx", ) tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-TTF.ttx +++ @@ -251,99 +251,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -417,42 +324,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -635,17 +539,17 @@ - + - + - + @@ -654,7 +558,7 @@ - + @@ -671,7 +575,7 @@ - + @@ -688,13 +592,13 @@ - + - + @@ -702,7 +606,7 @@ - + @@ -710,7 +614,7 @@ - + @@ -718,7 +622,7 @@ - + @@ -726,7 +630,7 @@ - + @@ -734,13 +638,13 @@ - + - + ______________ IntegrationTest.test_compileVariableCFF2s[ufoLib2] ______________ self = designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-CFF2.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx", ) tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx +++ @@ -128,99 +128,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -294,42 +201,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -692,17 +596,17 @@ - + - + - + @@ -711,7 +615,7 @@ - + @@ -728,7 +632,7 @@ - + @@ -745,13 +649,13 @@ - + - + @@ -759,7 +663,7 @@ - + @@ -767,7 +671,7 @@ - + @@ -775,7 +679,7 @@ - + @@ -783,7 +687,7 @@ - + @@ -791,13 +695,13 @@ - + - + _____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableTTFs] _____ self = FontClass = .ctor at 0x7fdac8861620> compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont ____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableCFF2s] _____ self = FontClass = .ctor at 0x7fdac8861620> compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont =============================== warnings summary =============================== .pybuild/cpython3_3.13_ufo2ft/build/tests/filters/dottedCircle_test.py::test_empty_font_deprecated[defcon] /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py:8: UserWarning: The dottedCircleFilter module is deprecated, please import dottedCircle instead. warnings.warn( .pybuild/cpython3_3.13_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_none[defcon-cff2] .pybuild/cpython3_3.13_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_specialize[defcon-cff2] .pybuild/cpython3_3.13_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_none[ufoLib2-cff2] .pybuild/cpython3_3.13_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_specialize[ufoLib2-cff2] /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/postProcessor.py:333: UserWarning: 'convertCFFtoCFF2' is deprecated; Use fontTools.cffLib.CFFToCFF2.convertCFFToCFF2 instead. convertCFFtoCFF2(otf) -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html --------------------------- snapshot report summary ---------------------------- 1 snapshot failed. 40 snapshots passed. =========================== short test summary info ============================ SKIPPED [2] tests/integration_test.py:137: skia-pathops is unavailable in debian yet SKIPPED [2] tests/integration_test.py:146: skia-pathops is unavailable in debian yet SKIPPED [2] tests/preProcessor_test.py:94: skia-pathops is unavailable in debian yet SKIPPED [2] tests/preProcessor_test.py:214: skia-pathops is unavailable in debian yet FAILED tests/featureWriters/kernFeatureWriter2_test.py::test_kern_zyyy_zinh[defcon] FAILED tests/featureWriters/kernFeatureWriter_test.py::test_kern_zyyy_zinh[defcon] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2_subroutinized[defcon] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTFs[defcon] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[defcon] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[defcon-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[defcon-compileVariableCFF2s] FAILED tests/featureWriters/kernFeatureWriter2_test.py::test_kern_zyyy_zinh[ufoLib2] FAILED tests/featureWriters/kernFeatureWriter_test.py::test_kern_zyyy_zinh[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2_subroutinized[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTFs[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableCFF2s] =========== 30 failed, 1102 passed, 8 skipped, 5 warnings in 23.50s ============ E: pybuild pybuild:389: test: plugin distutils failed with: exit code=1: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build; python3.13 -m pytest tests I: pybuild base:311: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build; python3.12 -m pytest tests ============================= test session starts ============================== platform linux -- Python 3.12.7, pytest-8.3.3, pluggy-1.5.0 rootdir: /build/reproducible-path/ufo2ft-3.3.1 configfile: setup.cfg plugins: typeguard-4.4.1, syrupy-4.7.2 collected 1140 items tests/featureCompiler_test.py ................ [ 1%] tests/featureWriters/cursFeatureWriter_test.py ......... [ 2%] tests/featureWriters/featureWriters_test.py ........ [ 2%] tests/featureWriters/gdefFeatureWriter_test.py .......... [ 3%] tests/featureWriters/kernFeatureWriter2_test.py ........................ [ 5%] ....F..... [ 6%] tests/featureWriters/kernFeatureWriter_test.py ......................... [ 8%] ......F..... [ 10%] tests/featureWriters/markFeatureWriter_test.py ......................... [ 12%] ............ [ 13%] tests/featureWriters/variableFeatureWriter_test.py .. [ 13%] tests/filters/decomposeComponents_test.py ...... [ 13%] tests/filters/decomposeTransformedComponents_test.py ... [ 14%] tests/filters/dottedCircle_test.py ... [ 14%] tests/filters/explodeColorLayerGlyphs_test.py . [ 14%] tests/filters/flattenComponents_test.py ........ [ 15%] tests/filters/propagateAnchors_test.py ............... [ 16%] tests/filters/sortContours_test.py .... [ 16%] tests/filters/transformations_test.py ............................... [ 19%] tests/fontInfoData_test.py ................ [ 21%] tests/infoCompiler_test.py ....... [ 21%] tests/instantiator_test.py ........................... [ 24%] tests/instructionCompiler_test.py ...................................... [ 27%] ......... [ 28%] tests/integration_test.py ......s.s.............FFFFFFF...FF.....FF..... [ 32%] ..............FF. [ 33%] tests/outlineCompiler_test.py .......................................... [ 37%] ........................................................................ [ 43%] ........................ [ 45%] tests/preProcessor_test.py ....s......s.............. [ 48%] tests/util_test.py . [ 48%] tests/featureCompiler_test.py ................ [ 49%] tests/featureWriters/cursFeatureWriter_test.py ......... [ 50%] tests/featureWriters/featureWriters_test.py ........ [ 51%] tests/featureWriters/gdefFeatureWriter_test.py .......... [ 51%] tests/featureWriters/kernFeatureWriter2_test.py ........................ [ 54%] ....F..... [ 54%] tests/featureWriters/kernFeatureWriter_test.py ......................... [ 57%] ......F..... [ 58%] tests/featureWriters/markFeatureWriter_test.py ......................... [ 60%] ............ [ 61%] tests/featureWriters/variableFeatureWriter_test.py .. [ 61%] tests/filters/decomposeComponents_test.py ...... [ 62%] tests/filters/decomposeTransformedComponents_test.py ... [ 62%] tests/filters/dottedCircle_test.py ... [ 62%] tests/filters/explodeColorLayerGlyphs_test.py . [ 62%] tests/filters/flattenComponents_test.py ........ [ 63%] tests/filters/propagateAnchors_test.py ............... [ 64%] tests/filters/sortContours_test.py .... [ 65%] tests/filters/transformations_test.py ............................... [ 67%] tests/fontInfoData_test.py ................ [ 69%] tests/infoCompiler_test.py ....... [ 69%] tests/instantiator_test.py ........................... [ 72%] tests/instructionCompiler_test.py ...................................... [ 75%] ......... [ 76%] tests/integration_test.py ......s.s.............FFFFFFF...FF.....FF..... [ 80%] ..............FF. [ 81%] tests/outlineCompiler_test.py .......................................... [ 85%] ........................................................................ [ 91%] ........................ [ 93%] tests/preProcessor_test.py ....s......s.............. [ 96%] tests/util_test.py . [ 96%] tests/featureWriters/ast_test.py . [ 96%] tests/featureWriters/markFeatureWriter_test.py ......... [ 97%] tests/filters/filters_test.py ................... [ 98%] tests/filters/transformations_test.py . [ 98%] tests/fontInfoData_test.py .. [ 99%] tests/instantiator_test.py .... [ 99%] tests/instructionCompiler_test.py .... [ 99%] tests/util_test.py .. [100%] =================================== FAILURES =================================== _________________________ test_kern_zyyy_zinh[defcon] __________________________ snapshot = ''' lookup kern_dflt { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni0310 uni0310 1; pos uni03...a; language dflt; lookup kern_dflt; script dupl; language dflt; lookup kern_dflt; } dist; ''' FontClass = def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert newFeatures.asFea() == snapshot E AssertionError: assert [+ received] == [- snapshot] E ''' E ... E lookupflag IgnoreMarks; E - pos uni0300 uni0300 0; E - pos uni0310 uni0310 1; E - pos uni0320 uni0320 2; E - pos uni0330 uni0330 3;... E E ...Full output truncated (85 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[defcon] __________________________ FontClass = def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert dedent(str(newFeatures)) == dedent( """\ lookup kern_Deva { lookupflag IgnoreMarks; pos uni1CD0 uni1CD0 7; pos uni1CE0 uni1CE0 8; pos uni1CF0 uni1CF0 9; pos uni20F0 uni20F0 11; pos uniA830 uniA830 34; } kern_Deva; lookup kern_Dupl { lookupflag IgnoreMarks; pos uni1BCA0 uni1BCA0 42; } kern_Dupl; lookup kern_Grek { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni1DC0 uni1DC0 10; } kern_Grek; lookup kern_Hani_Hrkt { lookupflag IgnoreMarks; pos uni1D360 uni1D360 43; pos uni1D370 uni1D370 44; pos uni1F250 uni1F250 45; pos uni2FF0 uni2FF0 13; pos uni3010 uni3010 14; pos uni3030 uni3030 15; pos uni30A0 uni30A0 16; pos uni3190 uni3190 17; pos uni31C0 uni31C0 18; pos uni31D0 uni31D0 19; pos uni31E0 uni31E0 20; pos uni3220 uni3220 21; pos uni3230 uni3230 22; pos uni3240 uni3240 23; pos uni3280 uni3280 24; pos uni3290 uni3290 25; pos uni32A0 uni32A0 26; pos uni32B0 uni32B0 27; pos uni32C0 uni32C0 28; pos uni3360 uni3360 29; pos uni3370 uni3370 30; pos uni33E0 uni33E0 31; pos uni33F0 uni33F0 32; pos uniA700 uniA700 33; pos uniFF70 uniFF70 35; } kern_Hani_Hrkt; lookup kern_Default { lookupflag IgnoreMarks; pos uni0310 uni0310 1; pos uni0320 uni0320 2; pos uni0330 uni0330 3; pos uni0640 uni0640 4; pos uni0650 uni0650 5; pos uni0670 uni0670 6; pos uni10100 uni10100 36; pos uni10110 uni10110 37; pos uni10120 uni10120 38; pos uni10130 uni10130 39; pos uni102E0 uni102E0 40; pos uni102F0 uni102F0 41; pos uni2E30 uni2E30 12; } kern_Default; feature kern { script DFLT; language dflt; lookup kern_Default; lookup kern_Grek; lookup kern_Hani_Hrkt; script grek; language dflt; lookup kern_Default; lookup kern_Grek; script hani; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; script kana; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; } kern; feature dist { script dev2; language dflt; lookup kern_Default; lookup kern_Deva; script deva; language dflt; lookup kern_Default; lookup kern_Deva; script dupl; language dflt; lookup kern_Default; lookup kern_Dupl; } dist; """ ) E AssertionError: assert 'lookup kern_...l;\n} dist;\n' == 'lookup kern_...l;\n} dist;\n' E E Skipping 61 identical leading characters in diff, use -v to show E - 0 uni1CD0 7; E ? ^ E + 0 uni1CD0 3; E ? ^ E - pos uni1CE0 uni1CE0 8;... E E ...Full output truncated (218 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError _____________ IntegrationTest.test_compileVariableTTF[defcon-None] _____________ self = designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _____________ IntegrationTest.test_compileVariableTTF[defcon-True] _____________ self = designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-useProductionNames.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[defcon-False] _____________ self = designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-None] _____________ self = designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-True] _____________ self = designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-useProductionNames.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[defcon-False] ____________ self = designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ________ IntegrationTest.test_compileVariableCFF2_subroutinized[defcon] ________ self = designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) > expectTTX(varfont, "TestVariableFont-CFF2-cffsubr.ttx") tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-cffsubr.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ self = designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-post3.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ self = designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-post3.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _______________ IntegrationTest.test_compileVariableTTFs[defcon] _______________ self = designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-TTF.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-TTF.ttx", ) tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-TTF.ttx +++ @@ -251,99 +251,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -417,42 +324,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -635,17 +539,17 @@ - + - + - + @@ -654,7 +558,7 @@ - + @@ -671,7 +575,7 @@ - + @@ -688,13 +592,13 @@ - + - + @@ -702,7 +606,7 @@ - + @@ -710,7 +614,7 @@ - + @@ -718,7 +622,7 @@ - + @@ -726,7 +630,7 @@ - + @@ -734,13 +638,13 @@ - + - + ______________ IntegrationTest.test_compileVariableCFF2s[defcon] _______________ self = designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-CFF2.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx", ) tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx +++ @@ -128,99 +128,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -294,42 +201,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -692,17 +596,17 @@ - + - + - + @@ -711,7 +615,7 @@ - + @@ -728,7 +632,7 @@ - + @@ -745,13 +649,13 @@ - + - + @@ -759,7 +663,7 @@ - + @@ -767,7 +671,7 @@ - + @@ -775,7 +679,7 @@ - + @@ -783,7 +687,7 @@ - + @@ -791,13 +695,13 @@ - + - + _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableTTFs] ______ self = FontClass = compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableCFF2s] _____ self = FontClass = compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ snapshot = ''' lookup kern_dflt { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni0310 uni0310 1; pos uni03...a; language dflt; lookup kern_dflt; script dupl; language dflt; lookup kern_dflt; } dist; ''' FontClass = .ctor at 0x7fd3b96b9620> def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert newFeatures.asFea() == snapshot E AssertionError: assert [+ received] == [- snapshot] E ''' E ... E lookupflag IgnoreMarks; E - pos uni0300 uni0300 0; E - pos uni0310 uni0310 1; E - pos uni0320 uni0320 2; E - pos uni0330 uni0330 3;... E E ...Full output truncated (85 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ FontClass = .ctor at 0x7fd3b96b9620> def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a disjoint set of explicit script extensions end up in the correct lookups.""" glyphs = {} for i in range(0, 0x110000, 0x10): script = unicodeScript(i) script_extension = unicodeScriptExtensions(i) if script not in script_extension: assert script in DFLT_SCRIPTS name = f"uni{i:04X}" glyphs[name] = i kerning = {(glyph, glyph): i for i, glyph in enumerate(glyphs)} ufo = makeUFO(FontClass, glyphs, None, kerning) newFeatures = KernFeatureWriterTest.writeFeatures(ufo) > assert dedent(str(newFeatures)) == dedent( """\ lookup kern_Deva { lookupflag IgnoreMarks; pos uni1CD0 uni1CD0 7; pos uni1CE0 uni1CE0 8; pos uni1CF0 uni1CF0 9; pos uni20F0 uni20F0 11; pos uniA830 uniA830 34; } kern_Deva; lookup kern_Dupl { lookupflag IgnoreMarks; pos uni1BCA0 uni1BCA0 42; } kern_Dupl; lookup kern_Grek { lookupflag IgnoreMarks; pos uni0300 uni0300 0; pos uni1DC0 uni1DC0 10; } kern_Grek; lookup kern_Hani_Hrkt { lookupflag IgnoreMarks; pos uni1D360 uni1D360 43; pos uni1D370 uni1D370 44; pos uni1F250 uni1F250 45; pos uni2FF0 uni2FF0 13; pos uni3010 uni3010 14; pos uni3030 uni3030 15; pos uni30A0 uni30A0 16; pos uni3190 uni3190 17; pos uni31C0 uni31C0 18; pos uni31D0 uni31D0 19; pos uni31E0 uni31E0 20; pos uni3220 uni3220 21; pos uni3230 uni3230 22; pos uni3240 uni3240 23; pos uni3280 uni3280 24; pos uni3290 uni3290 25; pos uni32A0 uni32A0 26; pos uni32B0 uni32B0 27; pos uni32C0 uni32C0 28; pos uni3360 uni3360 29; pos uni3370 uni3370 30; pos uni33E0 uni33E0 31; pos uni33F0 uni33F0 32; pos uniA700 uniA700 33; pos uniFF70 uniFF70 35; } kern_Hani_Hrkt; lookup kern_Default { lookupflag IgnoreMarks; pos uni0310 uni0310 1; pos uni0320 uni0320 2; pos uni0330 uni0330 3; pos uni0640 uni0640 4; pos uni0650 uni0650 5; pos uni0670 uni0670 6; pos uni10100 uni10100 36; pos uni10110 uni10110 37; pos uni10120 uni10120 38; pos uni10130 uni10130 39; pos uni102E0 uni102E0 40; pos uni102F0 uni102F0 41; pos uni2E30 uni2E30 12; } kern_Default; feature kern { script DFLT; language dflt; lookup kern_Default; lookup kern_Grek; lookup kern_Hani_Hrkt; script grek; language dflt; lookup kern_Default; lookup kern_Grek; script hani; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; script kana; language dflt; lookup kern_Default; lookup kern_Hani_Hrkt; } kern; feature dist { script dev2; language dflt; lookup kern_Default; lookup kern_Deva; script deva; language dflt; lookup kern_Default; lookup kern_Deva; script dupl; language dflt; lookup kern_Default; lookup kern_Dupl; } dist; """ ) E AssertionError: assert 'lookup kern_...l;\n} dist;\n' == 'lookup kern_...l;\n} dist;\n' E E Skipping 61 identical leading characters in diff, use -v to show E - 0 uni1CD0 7; E ? ^ E + 0 uni1CD0 3; E ? ^ E - pos uni1CE0 uni1CE0 8;... E E ...Full output truncated (218 lines hidden), use '-vv' to show tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-None] _____________ self = designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-True] _____________ self = designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-useProductionNames.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-False] ____________ self = designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): varfont = compileVariableTTF(designspace, useProductionNames=useProductionNames) > expectTTX( varfont, "TestVariableFont-TTF{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-None] ____________ self = designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-True] ____________ self = designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-useProductionNames.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ___________ IntegrationTest.test_compileVariableCFF2[ufoLib2-False] ____________ self = designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): varfont = compileVariableCFF2( designspace, useProductionNames=useProductionNames ) > expectTTX( varfont, "TestVariableFont-CFF2{}.ttx".format( "-useProductionNames" if useProductionNames else "" ), ) tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _______ IntegrationTest.test_compileVariableCFF2_subroutinized[ufoLib2] ________ self = designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) > expectTTX(varfont, "TestVariableFont-CFF2-cffsubr.ttx") tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-cffsubr.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ self = designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-TTF-post3.ttx +++ @@ -257,9 +257,6 @@ - - Weight - Layer Font _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ self = designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @pytest.mark.parametrize( "output_format, options, expected_ttx", [ ("VariableTTF", {}, "TestVariableFont-TTF-post3.ttx"), ("VariableCFF2", {}, "TestVariableFont-CFF2-post3.ttx"), ], ) def test_drop_glyph_names_variable( self, designspace, output_format, options, expected_ttx ): # set keepGlyphNames in the default UFO.lib where postProcessor finds it designspace.findDefault().font.lib[KEEP_GLYPH_NAMES] = False compile_func = globals()[f"compile{output_format}"] ttf = compile_func(designspace, **options) > expectTTX(ttf, expected_ttx) tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVariableFont-CFF2-post3.ttx +++ @@ -138,9 +138,6 @@ - - Weight - Layer Font ______________ IntegrationTest.test_compileVariableTTFs[ufoLib2] _______________ self = designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-TTF.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-TTF.ttx", ) tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-TTF.ttx +++ @@ -251,99 +251,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -417,42 +324,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -635,17 +539,17 @@ - + - + - + @@ -654,7 +558,7 @@ - + @@ -671,7 +575,7 @@ - + @@ -688,13 +592,13 @@ - + - + @@ -702,7 +606,7 @@ - + @@ -710,7 +614,7 @@ - + @@ -718,7 +622,7 @@ - + @@ -726,7 +630,7 @@ - + @@ -734,13 +638,13 @@ - + - + ______________ IntegrationTest.test_compileVariableCFF2s[ufoLib2] ______________ self = designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) # NOTE: Test dumps were generated like this: # for k, font in fonts.items(): # font.recalcTimestamp = False # font["head"].created, font["head"].modified = 3570196637, 3601822698 # font["head"].checkSumAdjustment = 0x12345678 # font.saveXML(f"tests/data/DSv5/{k}-CFF2.ttx") assert set(fonts.keys()) == { "MutatorSansVariable_Weight_Width", "MutatorSansVariable_Weight", "MutatorSansVariable_Width", "MutatorSerifVariable_Width", } # The STAT table is set to [SRIF=0, wght=[300, 700], wdth=[50, 200]] + S1 + S2 > expectTTX( fonts["MutatorSansVariable_Weight_Width"], "DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx", ) tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx +++ @@ -128,99 +128,6 @@ - - Weight - - - Width - - - Sans Light Condensed - - - MutatorMathTest-SansLightCondensed - - - Sans Bold Condensed - - - MutatorMathTest-SansBoldCondensed - - - Sans Light Extended - - - MutatorMathTest-SansLightExtended - - - Sans Bold Extended - - - MutatorMathTest-SansBoldExtended - - - Sans Medium - - - MutatorMathTest-SansMedium - - - MutatorMathTest-SansMedium - - - Sans Bold - - - MutatorMathTest-SansBold - - - Sans Medium Extended - - - MutatorMathTest-SansMediumExtended - - - MutatorMathTest-SansLightCondensed - - - Regular - - - serif - - - Sans - - - weight - - - Light - - - Medium - - - Bold - - - width - - - Condensed - - - Normal - - - Extended - - - S1 - - - S2 - New Font @@ -294,42 +201,39 @@ MutatorMathTest-SansLightCondensed - Regular + serif - serif + Sans - Sans + weight - weight + Light - Light + Medium - Medium + Bold - Bold + width - width + Condensed - Condensed + Normal - Normal + Extended - Extended + S1 - S1 - - S2 @@ -692,17 +596,17 @@ - + - + - + @@ -711,7 +615,7 @@ - + @@ -728,7 +632,7 @@ - + @@ -745,13 +649,13 @@ - + - + @@ -759,7 +663,7 @@ - + @@ -767,7 +671,7 @@ - + @@ -775,7 +679,7 @@ - + @@ -783,7 +687,7 @@ - + @@ -791,13 +695,13 @@ - + - + _____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableTTFs] _____ self = FontClass = .ctor at 0x7fd3b96b9620> compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont ____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableCFF2s] _____ self = FontClass = .ctor at 0x7fd3b96b9620> compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] ) def test_apply_varfont_info(self, FontClass, compileMethod): designspace = DesignSpaceDocument.fromfile(getpath("TestVarFont.designspace")) designspace.loadSourceFonts(FontClass) fonts = compileMethod(designspace) assert len(fonts) == 2 > expectTTX(fonts["MyFontVF1"], "TestVarFont-MyFontVF1.ttx", ["head", "name"]) tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): with open(getpath(expectedTTX), encoding="utf-8") as f: expected = readLines(f) font.recalcTimestamp = False font["head"].created, font["head"].modified = 3570196637, 3601822698 font["head"].checkSumAdjustment = 0x12345678 f = io.StringIO() font.saveXML(f, tables=tables) actual = readLines(f) if actual != expected: for line in difflib.unified_diff( expected, actual, fromfile=expectedTTX, tofile="" ): sys.stderr.write(line) > pytest.fail("TTX output is different from expected") E Failed: TTX output is different from expected tests/integration_test.py:73: Failed ----------------------------- Captured stderr call ----------------------------- --- TestVarFont-MyFontVF1.ttx +++ @@ -23,9 +23,6 @@ - - Weight - TestVarFont =============================== warnings summary =============================== .pybuild/cpython3_3.12_ufo2ft/build/tests/filters/dottedCircle_test.py::test_empty_font_deprecated[defcon] /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py:8: UserWarning: The dottedCircleFilter module is deprecated, please import dottedCircle instead. warnings.warn( .pybuild/cpython3_3.12_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_none[defcon-cff2] .pybuild/cpython3_3.12_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_specialize[defcon-cff2] .pybuild/cpython3_3.12_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_none[ufoLib2-cff2] .pybuild/cpython3_3.12_ufo2ft/build/tests/integration_test.py::IntegrationTest::test_optimizeCFF_specialize[ufoLib2-cff2] /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/postProcessor.py:333: UserWarning: 'convertCFFtoCFF2' is deprecated; Use fontTools.cffLib.CFFToCFF2.convertCFFToCFF2 instead. convertCFFtoCFF2(otf) -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html --------------------------- snapshot report summary ---------------------------- 1 snapshot failed. 40 snapshots passed. =========================== short test summary info ============================ SKIPPED [2] tests/integration_test.py:137: skia-pathops is unavailable in debian yet SKIPPED [2] tests/integration_test.py:146: skia-pathops is unavailable in debian yet SKIPPED [2] tests/preProcessor_test.py:94: skia-pathops is unavailable in debian yet SKIPPED [2] tests/preProcessor_test.py:214: skia-pathops is unavailable in debian yet FAILED tests/featureWriters/kernFeatureWriter2_test.py::test_kern_zyyy_zinh[defcon] FAILED tests/featureWriters/kernFeatureWriter_test.py::test_kern_zyyy_zinh[defcon] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[defcon-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[defcon-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2_subroutinized[defcon] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTFs[defcon] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[defcon] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[defcon-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[defcon-compileVariableCFF2s] FAILED tests/featureWriters/kernFeatureWriter2_test.py::test_kern_zyyy_zinh[ufoLib2] FAILED tests/featureWriters/kernFeatureWriter_test.py::test_kern_zyyy_zinh[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTF[ufoLib2-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-None] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-True] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2[ufoLib2-False] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2_subroutinized[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableTTFs[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableCFF2s] =========== 30 failed, 1102 passed, 8 skipped, 5 warnings in 23.95s ============ E: pybuild pybuild:389: test: plugin distutils failed with: exit code=1: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build; python3.12 -m pytest tests dh_auto_test: error: pybuild --test --test-pytest -i python{version} -p "3.13 3.12" returned exit code 13 make[1]: [debian/rules:15: override_dh_auto_test] Error 25 (ignored) make[1]: Leaving directory '/build/reproducible-path/ufo2ft-3.3.1' create-stamp debian/debhelper-build-stamp fakeroot debian/rules binary dh binary --buildsystem=pybuild dh_testroot -O--buildsystem=pybuild dh_prep -O--buildsystem=pybuild dh_auto_install --destdir=debian/python3-ufo2ft/ -O--buildsystem=pybuild I: pybuild base:311: /usr/bin/python3.13 setup.py install --root /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running install /usr/lib/python3/dist-packages/setuptools/_distutils/cmd.py:66: SetuptoolsDeprecationWarning: setup.py install is deprecated. !! ******************************************************************************** Please avoid running ``setup.py`` directly. Instead, use pypa/build, pypa/installer or other standards-based tools. See https://blog.ganssle.io/articles/2021/10/setup-py-deprecated.html for details. ******************************************************************************** !! self.initialize_options() running build running build_py copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft running egg_info writing Lib/ufo2ft.egg-info/PKG-INFO writing dependency_links to Lib/ufo2ft.egg-info/dependency_links.txt writing requirements to Lib/ufo2ft.egg-info/requires.txt writing top-level names to Lib/ufo2ft.egg-info/top_level.txt reading manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' adding license file 'LICENSE' writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' running install_lib creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/baseFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/ast.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter2.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/markFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/cursFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/gdefFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/propagateAnchors.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/transformations.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeTransformedComponents.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/explodeColorLayerGlyphs.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/cubicToQuadratic.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircle.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/sortContours.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/removeOverlaps.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircleFilter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/base.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/flattenComponents.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/skipExportGlyphs.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeComponents.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/reverseContourDirection.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/otfCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableCFF2sCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/ttfCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableTTFsCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableTTFCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableOTFCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/baseCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/_version.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/constants.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/fontInfoData.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/util.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/instantiator.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/outlineCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/postProcessor.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/infoCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/featureCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/instructionCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/preProcessor.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/errors.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/preProcessor.py to preProcessor.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/kernFeatureWriter.py to kernFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/markFeatureWriter.py to markFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__main__.py to __main__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/baseFeatureWriter.py to baseFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/cursFeatureWriter.py to cursFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/kernFeatureWriter2.py to kernFeatureWriter2.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/gdefFeatureWriter.py to gdefFeatureWriter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/ast.py to ast.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/base.py to base.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/decomposeComponents.py to decomposeComponents.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/sortContours.py to sortContours.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/skipExportGlyphs.py to skipExportGlyphs.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/flattenComponents.py to flattenComponents.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__main__.py to __main__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/removeOverlaps.py to removeOverlaps.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/cubicToQuadratic.py to cubicToQuadratic.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/dottedCircleFilter.py to dottedCircleFilter.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/propagateAnchors.py to propagateAnchors.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/reverseContourDirection.py to reverseContourDirection.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/decomposeTransformedComponents.py to decomposeTransformedComponents.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/transformations.py to transformations.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/explodeColorLayerGlyphs.py to explodeColorLayerGlyphs.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/dottedCircle.py to dottedCircle.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/otfCompiler.py to otfCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/interpolatableTTFCompiler.py to interpolatableTTFCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/ttfCompiler.py to ttfCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/baseCompiler.py to baseCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/variableCFF2sCompiler.py to variableCFF2sCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/variableTTFsCompiler.py to variableTTFsCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/interpolatableOTFCompiler.py to interpolatableOTFCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/fontInfoData.py to fontInfoData.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/instantiator.py to instantiator.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/errors.py to errors.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/postProcessor.py to postProcessor.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureCompiler.py to featureCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_version.py to _version.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/instructionCompiler.py to instructionCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/constants.py to constants.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/maxContextCalc.py to maxContextCalc.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/outlineCompiler.py to outlineCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/infoCompiler.py to infoCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/util.py to util.cpython-313.pyc running install_egg_info Copying Lib/ufo2ft.egg-info to /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft-3.3.1.egg-info Skipping SOURCES.txt running install_scripts I: pybuild base:311: /usr/bin/python3 setup.py install --root /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated. !! ******************************************************************************** Requirements should be satisfied by a PEP 517 installer. If you are using pip, you can try `pip install --use-pep517`. ******************************************************************************** !! dist.fetch_build_eggs(dist.setup_requires) /usr/lib/python3/dist-packages/setuptools/_distutils/dist.py:261: UserWarning: Unknown distribution option: 'tests_require' warnings.warn(msg) WARNING setuptools_scm.pyproject_reading toml section missing 'pyproject.toml does not contain a tool.setuptools_scm section' Traceback (most recent call last): File "/usr/lib/python3/dist-packages/setuptools_scm/_integration/pyproject_reading.py", line 36, in read_pyproject section = defn.get("tool", {})[tool_name] ~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^ KeyError: 'setuptools_scm' running install /usr/lib/python3/dist-packages/setuptools/_distutils/cmd.py:66: SetuptoolsDeprecationWarning: setup.py install is deprecated. !! ******************************************************************************** Please avoid running ``setup.py`` directly. Instead, use pypa/build, pypa/installer or other standards-based tools. See https://blog.ganssle.io/articles/2021/10/setup-py-deprecated.html for details. ******************************************************************************** !! self.initialize_options() running build running build_py copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft running egg_info writing Lib/ufo2ft.egg-info/PKG-INFO writing dependency_links to Lib/ufo2ft.egg-info/dependency_links.txt writing requirements to Lib/ufo2ft.egg-info/requires.txt writing top-level names to Lib/ufo2ft.egg-info/top_level.txt reading manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' adding license file 'LICENSE' writing manifest file 'Lib/ufo2ft.egg-info/SOURCES.txt' running install_lib creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/gdefFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/markFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/baseFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter2.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/cursFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/ast.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/cubicToQuadratic.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/removeOverlaps.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/propagateAnchors.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/reverseContourDirection.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircle.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/skipExportGlyphs.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/explodeColorLayerGlyphs.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/transformations.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/sortContours.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/base.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircleFilter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeTransformedComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/flattenComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableTTFsCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/baseCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableOTFCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableTTFCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/ttfCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/otfCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableCFF2sCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/instantiator.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/constants.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/fontInfoData.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/instructionCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/outlineCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/util.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/_version.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/postProcessor.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/featureCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/errors.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/infoCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/preProcessor.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/preProcessor.py to preProcessor.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/kernFeatureWriter.py to kernFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/markFeatureWriter.py to markFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__main__.py to __main__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/baseFeatureWriter.py to baseFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/cursFeatureWriter.py to cursFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/kernFeatureWriter2.py to kernFeatureWriter2.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/gdefFeatureWriter.py to gdefFeatureWriter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/ast.py to ast.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/base.py to base.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/decomposeComponents.py to decomposeComponents.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/sortContours.py to sortContours.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/skipExportGlyphs.py to skipExportGlyphs.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/flattenComponents.py to flattenComponents.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__main__.py to __main__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/removeOverlaps.py to removeOverlaps.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/cubicToQuadratic.py to cubicToQuadratic.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/dottedCircleFilter.py to dottedCircleFilter.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/propagateAnchors.py to propagateAnchors.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/reverseContourDirection.py to reverseContourDirection.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/decomposeTransformedComponents.py to decomposeTransformedComponents.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/transformations.py to transformations.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/explodeColorLayerGlyphs.py to explodeColorLayerGlyphs.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/dottedCircle.py to dottedCircle.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/otfCompiler.py to otfCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/interpolatableTTFCompiler.py to interpolatableTTFCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/ttfCompiler.py to ttfCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/baseCompiler.py to baseCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/variableCFF2sCompiler.py to variableCFF2sCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/variableTTFsCompiler.py to variableTTFsCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/interpolatableOTFCompiler.py to interpolatableOTFCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/fontInfoData.py to fontInfoData.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/instantiator.py to instantiator.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/errors.py to errors.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/postProcessor.py to postProcessor.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureCompiler.py to featureCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_version.py to _version.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/instructionCompiler.py to instructionCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/constants.py to constants.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/maxContextCalc.py to maxContextCalc.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/outlineCompiler.py to outlineCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/infoCompiler.py to infoCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/util.py to util.cpython-312.pyc running install_egg_info Copying Lib/ufo2ft.egg-info to /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft-3.3.1.egg-info Skipping SOURCES.txt running install_scripts dh_installdocs -O--buildsystem=pybuild dh_installchangelogs -O--buildsystem=pybuild dh_python3 -O--buildsystem=pybuild dh_installsystemduser -O--buildsystem=pybuild dh_perl -O--buildsystem=pybuild dh_link -O--buildsystem=pybuild dh_strip_nondeterminism -O--buildsystem=pybuild dh_compress -O--buildsystem=pybuild dh_fixperms -O--buildsystem=pybuild dh_missing -O--buildsystem=pybuild dh_installdeb -O--buildsystem=pybuild dh_gencontrol -O--buildsystem=pybuild dh_md5sums -O--buildsystem=pybuild dh_builddeb -O--buildsystem=pybuild dpkg-deb: building package 'python3-ufo2ft' in '../python3-ufo2ft_3.3.1-2_all.deb'. dpkg-genbuildinfo --build=binary -O../ufo2ft_3.3.1-2_amd64.buildinfo dpkg-genchanges --build=binary -O../ufo2ft_3.3.1-2_amd64.changes dpkg-genchanges: info: binary-only upload (no source code included) dpkg-source --after-build . dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: not including original source code in upload I: copying local configuration I: user script /srv/workspace/pbuilder/501244/tmp/hooks/B01_cleanup starting I: user script /srv/workspace/pbuilder/501244/tmp/hooks/B01_cleanup finished I: unmounting dev/ptmx filesystem I: unmounting dev/pts filesystem I: unmounting dev/shm filesystem I: unmounting proc filesystem I: unmounting sys filesystem I: cleaning the build env I: removing directory /srv/workspace/pbuilder/501244 and its subdirectories I: Current time: Sun Dec 28 15:58:27 +14 2025 I: pbuilder-time-stamp: 1766887107 + false + set +x Sun Dec 28 01:58:27 UTC 2025 I: Signing ./b2/ufo2ft_3.3.1-2_amd64.buildinfo as ufo2ft_3.3.1-2_amd64.buildinfo.asc Sun Dec 28 01:58:27 UTC 2025 I: Signed ./b2/ufo2ft_3.3.1-2_amd64.buildinfo as ./b2/ufo2ft_3.3.1-2_amd64.buildinfo.asc Sun Dec 28 01:58:27 UTC 2025 - build #2 for ufo2ft/unstable/amd64 on ionos15-amd64 done. Starting cleanup. All cleanup done. Sun Dec 28 01:58:27 UTC 2025 - reproducible_build.sh stopped running as /tmp/jenkins-script-Abn2TQCR, removing. /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf: total 392 drwxr-xr-x 2 jenkins jenkins 4096 Nov 24 19:33 b1 drwxr-xr-x 2 jenkins jenkins 4096 Nov 24 19:35 b2 -rw------- 1 jenkins jenkins 380965 Nov 24 19:33 rbuildlog.ltArHKm -rw-r--r-- 1 jenkins jenkins 2508 Oct 23 13:44 ufo2ft_3.3.1-2.dsc /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b1: total 532 -rw-r--r-- 1 jenkins jenkins 377074 Nov 24 19:33 build.log -rw-r--r-- 1 jenkins jenkins 114788 Nov 24 19:33 python3-ufo2ft_3.3.1-2_all.deb -rw-r--r-- 1 jenkins jenkins 6224 Nov 24 19:33 ufo2ft_3.3.1-2.debian.tar.xz -rw-r--r-- 1 jenkins jenkins 2508 Nov 24 19:33 ufo2ft_3.3.1-2.dsc -rw-r--r-- 1 jenkins jenkins 7281 Nov 24 19:33 ufo2ft_3.3.1-2_amd64.buildinfo -rw-r--r-- 1 jenkins jenkins 8163 Nov 24 19:33 ufo2ft_3.3.1-2_amd64.buildinfo.asc -rw-r--r-- 1 jenkins jenkins 1167 Nov 24 19:33 ufo2ft_3.3.1-2_amd64.changes -rw-r--r-- 1 jenkins jenkins 1294 Nov 24 19:33 ufo2ft_3.3.1-2_source.changes /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b2: total 524 -rw-r--r-- 1 jenkins jenkins 379010 Nov 24 19:35 build.log -rw-r--r-- 1 jenkins jenkins 114788 Nov 24 19:35 python3-ufo2ft_3.3.1-2_all.deb -rw-r--r-- 1 jenkins jenkins 6224 Nov 24 19:35 ufo2ft_3.3.1-2.debian.tar.xz -rw-r--r-- 1 jenkins jenkins 2508 Nov 24 19:35 ufo2ft_3.3.1-2.dsc -rw-r--r-- 1 jenkins jenkins 7290 Nov 24 19:35 ufo2ft_3.3.1-2_amd64.buildinfo -rw-r--r-- 1 jenkins jenkins 8172 Nov 24 19:35 ufo2ft_3.3.1-2_amd64.buildinfo.asc -rw-r--r-- 1 jenkins jenkins 1167 Nov 24 19:35 ufo2ft_3.3.1-2_amd64.changes -rw-r--r-- 1 jenkins jenkins 1294 Nov 24 19:35 ufo2ft_3.3.1-2_source.changes Sun Nov 24 19:35:28 UTC 2024 I: Deleting $TMPDIR on ionos15-amd64.debian.net. Sun Nov 24 19:35:29 UTC 2024 I: ufo2ft_3.3.1-2_amd64.changes: Format: 1.8 Date: Wed, 23 Oct 2024 09:27:37 -0400 Source: ufo2ft Binary: python3-ufo2ft Architecture: all Version: 3.3.1-2 Distribution: unstable Urgency: medium Maintainer: Debian Fonts Task Force Changed-By: Boyuan Yang Description: python3-ufo2ft - Bridge from UFOs to fonttools objects Changes: ufo2ft (3.3.1-2) unstable; urgency=medium . * Team upload. * debian/control: Tighten version requirement for ufolib2. * debian/control: Let binary package breaks python3-glyphslib (<< 6.9.2) for autopkgtest compatibility. Checksums-Sha1: 4d1af2478c53fa1b26fd43e63c487908a9e4867b 114788 python3-ufo2ft_3.3.1-2_all.deb 9c999b69bef67479fe7d9027cba52ec6cb864a85 7281 ufo2ft_3.3.1-2_amd64.buildinfo Checksums-Sha256: b386e875fd693a47f87b6cc9ec21dc76d2ec5c16ffb871d87c7ad75ed2376003 114788 python3-ufo2ft_3.3.1-2_all.deb fc4e770d9457c6a9d980d598497c68063d2a5e12f42f727f14e3067328e28753 7281 ufo2ft_3.3.1-2_amd64.buildinfo Files: 55467c44759f3e79f25bb48c8ea85a82 114788 python optional python3-ufo2ft_3.3.1-2_all.deb 99808167be3fbf0985526bec0d6d01fa 7281 fonts optional ufo2ft_3.3.1-2_amd64.buildinfo removed '/var/lib/jenkins/userContent/reproducible/debian/rbuild/unstable/amd64/ufo2ft_3.3.1-2.rbuild.log' removed '/var/lib/jenkins/userContent/reproducible/debian/rbuild/unstable/amd64/ufo2ft_3.3.1-2.rbuild.log.gz' removed '/var/lib/jenkins/userContent/reproducible/debian/logs/unstable/amd64/ufo2ft_3.3.1-2.build1.log.gz' removed '/var/lib/jenkins/userContent/reproducible/debian/logs/unstable/amd64/ufo2ft_3.3.1-2.build2.log.gz' removed '/var/lib/jenkins/userContent/reproducible/debian/buildinfo/unstable/amd64/ufo2ft_3.3.1-2_amd64.buildinfo' removed '/var/lib/jenkins/userContent/reproducible/debian/logdiffs/unstable/amd64/ufo2ft_3.3.1-2.diff.gz' Diff of the two buildlogs: -- --- b1/build.log 2024-11-24 19:33:15.385875403 +0000 +++ b2/build.log 2024-11-24 19:35:28.823829230 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Sun Nov 24 07:22:45 -12 2024 -I: pbuilder-time-stamp: 1732476165 +I: Current time: Sun Dec 28 15:56:17 +14 2025 +I: pbuilder-time-stamp: 1766886977 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/unstable-reproducible-base.tgz] I: copying local configuration @@ -28,52 +28,84 @@ dpkg-source: info: applying Add-files-to-avoid-clean-target-failure.patch I: using fakeroot in build. I: Installing the build-deps -I: user script /srv/workspace/pbuilder/894615/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/501244/tmp/hooks/D01_modify_environment starting +debug: Running on ionos15-amd64. +I: Changing host+domainname to test build reproducibility +I: Adding a custom variable just for the fun of it... +I: Changing /bin/sh to bash +'/bin/sh' -> '/bin/bash' +lrwxrwxrwx 1 root root 9 Dec 28 01:56 /bin/sh -> /bin/bash +I: Setting pbuilder2's login shell to /bin/bash +I: Setting pbuilder2's GECOS to second user,second room,second work-phone,second home-phone,second other +I: user script /srv/workspace/pbuilder/501244/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/501244/tmp/hooks/D02_print_environment starting I: set - BUILDDIR='/build/reproducible-path' - BUILDUSERGECOS='first user,first room,first work-phone,first home-phone,first other' - BUILDUSERNAME='pbuilder1' - BUILD_ARCH='amd64' - DEBIAN_FRONTEND='noninteractive' - DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=20 ' - DISTRIBUTION='unstable' - HOME='/root' - HOST_ARCH='amd64' + BASH=/bin/sh + BASHOPTS=checkwinsize:cmdhist:complete_fullquote:extquote:force_fignore:globasciiranges:globskipdots:hostcomplete:interactive_comments:patsub_replacement:progcomp:promptvars:sourcepath + BASH_ALIASES=() + BASH_ARGC=() + BASH_ARGV=() + BASH_CMDS=() + BASH_LINENO=([0]="12" [1]="0") + BASH_LOADABLES_PATH=/usr/local/lib/bash:/usr/lib/bash:/opt/local/lib/bash:/usr/pkg/lib/bash:/opt/pkg/lib/bash:. + BASH_SOURCE=([0]="/tmp/hooks/D02_print_environment" [1]="/tmp/hooks/D02_print_environment") + BASH_VERSINFO=([0]="5" [1]="2" [2]="32" [3]="1" [4]="release" [5]="x86_64-pc-linux-gnu") + BASH_VERSION='5.2.32(1)-release' + BUILDDIR=/build/reproducible-path + BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' + BUILDUSERNAME=pbuilder2 + BUILD_ARCH=amd64 + DEBIAN_FRONTEND=noninteractive + DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=42 ' + DIRSTACK=() + DISTRIBUTION=unstable + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=x86_64 + HOST_ARCH=amd64 IFS=' ' - INVOCATION_ID='8b467b916a84408090859ead7c9f7d87' - LANG='C' - LANGUAGE='en_US:en' - LC_ALL='C' - MAIL='/var/mail/root' - OPTIND='1' - PATH='/usr/sbin:/usr/bin:/sbin:/bin:/usr/games' - PBCURRENTCOMMANDLINEOPERATION='build' - PBUILDER_OPERATION='build' - PBUILDER_PKGDATADIR='/usr/share/pbuilder' - PBUILDER_PKGLIBDIR='/usr/lib/pbuilder' - PBUILDER_SYSCONFDIR='/etc' - PPID='894615' - PS1='# ' - PS2='> ' + INVOCATION_ID=f22def810bd54dc1b6b299343c78a235 + LANG=C + LANGUAGE=et_EE:et + LC_ALL=C + MACHTYPE=x86_64-pc-linux-gnu + MAIL=/var/mail/root + OPTERR=1 + OPTIND=1 + OSTYPE=linux-gnu + PATH=/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path + PBCURRENTCOMMANDLINEOPERATION=build + PBUILDER_OPERATION=build + PBUILDER_PKGDATADIR=/usr/share/pbuilder + PBUILDER_PKGLIBDIR=/usr/lib/pbuilder + PBUILDER_SYSCONFDIR=/etc + PIPESTATUS=([0]="0") + POSIXLY_CORRECT=y + PPID=501244 PS4='+ ' - PWD='/' - SHELL='/bin/bash' - SHLVL='2' - SUDO_COMMAND='/usr/bin/timeout -k 18.1h 18h /usr/bin/ionice -c 3 /usr/bin/nice /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/pbuilderrc_0MIM --distribution unstable --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b1 --logfile b1/build.log ufo2ft_3.3.1-2.dsc' - SUDO_GID='111' - SUDO_UID='106' - SUDO_USER='jenkins' - TERM='unknown' - TZ='/usr/share/zoneinfo/Etc/GMT+12' - USER='root' - _='/usr/bin/systemd-run' - http_proxy='http://46.16.76.132:3128' + PWD=/ + SHELL=/bin/bash + SHELLOPTS=braceexpand:errexit:hashall:interactive-comments:posix + SHLVL=3 + SUDO_COMMAND='/usr/bin/timeout -k 24.1h 24h /usr/bin/ionice -c 3 /usr/bin/nice -n 11 /usr/bin/unshare --uts -- /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/pbuilderrc_T0kl --distribution unstable --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b2 --logfile b2/build.log ufo2ft_3.3.1-2.dsc' + SUDO_GID=111 + SUDO_UID=106 + SUDO_USER=jenkins + TERM=unknown + TZ=/usr/share/zoneinfo/Etc/GMT-14 + UID=0 + USER=root + _='I: set' + http_proxy=http://213.165.73.152:3128 I: uname -a - Linux ionos11-amd64 6.1.0-27-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.115-1 (2024-11-01) x86_64 GNU/Linux + Linux i-capture-the-hostname 6.11.5+bpo-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.11.5-1~bpo12+1 (2024-11-11) x86_64 GNU/Linux I: ls -l /bin - lrwxrwxrwx 1 root root 7 Nov 22 14:40 /bin -> usr/bin -I: user script /srv/workspace/pbuilder/894615/tmp/hooks/D02_print_environment finished + lrwxrwxrwx 1 root root 7 Nov 22 2024 /bin -> usr/bin +I: user script /srv/workspace/pbuilder/501244/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy @@ -241,7 +273,7 @@ Get: 104 http://deb.debian.org/debian unstable/main amd64 python3-pytest all 8.3.3-1 [249 kB] Get: 105 http://deb.debian.org/debian unstable/main amd64 python3-setuptools-scm all 8.1.0-1 [40.5 kB] Get: 106 http://deb.debian.org/debian unstable/main amd64 python3-syrupy all 4.7.2-1 [53.0 kB] -Fetched 82.8 MB in 19s (4337 kB/s) +Fetched 82.8 MB in 7s (12.6 MB/s) debconf: delaying package configuration, since apt-utils is not installed Selecting previously unselected package libpython3.12-minimal:amd64. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 19966 files and directories currently installed.) @@ -594,8 +626,8 @@ Setting up tzdata (2024b-3) ... Current default time zone: 'Etc/UTC' -Local time is now: Sun Nov 24 19:25:46 UTC 2024. -Universal Time is now: Sun Nov 24 19:25:46 UTC 2024. +Local time is now: Sun Dec 28 01:56:47 UTC 2025. +Universal Time is now: Sun Dec 28 01:56:47 UTC 2025. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up unicode-data (15.1.0-1) ... @@ -701,7 +733,11 @@ fakeroot is already the newest version (1.36-1). 0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. I: Building the package -I: Running cd /build/reproducible-path/ufo2ft-3.3.1/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-genchanges -S > ../ufo2ft_3.3.1-2_source.changes +I: user script /srv/workspace/pbuilder/501244/tmp/hooks/A99_set_merged_usr starting +Not re-configuring usrmerge for unstable +I: user script /srv/workspace/pbuilder/501244/tmp/hooks/A99_set_merged_usr finished +hostname: Name or service not known +I: Running cd /build/reproducible-path/ufo2ft-3.3.1/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-genchanges -S > ../ufo2ft_3.3.1-2_source.changes dpkg-buildpackage: info: source package ufo2ft dpkg-buildpackage: info: source version 3.3.1-2 dpkg-buildpackage: info: source distribution unstable @@ -831,56 +867,56 @@ running build running build_py creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft copying Lib/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft -creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers +creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters -creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters +creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers running egg_info creating Lib/ufo2ft.egg-info writing Lib/ufo2ft.egg-info/PKG-INFO @@ -914,56 +950,56 @@ running build running build_py creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft +copying Lib/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft copying Lib/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft -copying Lib/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft -creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers -copying Lib/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers +creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters -copying Lib/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters copying Lib/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters -creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters -copying Lib/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters +copying Lib/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters +copying Lib/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters +creating /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers +copying Lib/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers running egg_info writing Lib/ufo2ft.egg-info/PKG-INFO writing dependency_links to Lib/ufo2ft.egg-info/dependency_links.txt @@ -982,7 +1018,7 @@ platform linux -- Python 3.13.0, pytest-8.3.3, pluggy-1.5.0 rootdir: /build/reproducible-path/ufo2ft-3.3.1 configfile: setup.cfg -plugins: syrupy-4.7.2, typeguard-4.4.1 +plugins: typeguard-4.4.1, syrupy-4.7.2 collected 1140 items tests/featureCompiler_test.py ................ [ 1%] @@ -1246,8 +1282,8 @@ tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError _____________ IntegrationTest.test_compileVariableTTF[defcon-None] _____________ -self = -designspace = +self = +designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): @@ -1262,7 +1298,7 @@ tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -1299,8 +1335,8 @@ _____________ IntegrationTest.test_compileVariableTTF[defcon-True] _____________ -self = -designspace = +self = +designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): @@ -1315,7 +1351,7 @@ tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -1352,8 +1388,8 @@ ____________ IntegrationTest.test_compileVariableTTF[defcon-False] _____________ -self = -designspace = +self = +designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): @@ -1368,7 +1404,7 @@ tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -1405,8 +1441,8 @@ ____________ IntegrationTest.test_compileVariableCFF2[defcon-None] _____________ -self = -designspace = +self = +designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): @@ -1423,7 +1459,7 @@ tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -1460,8 +1496,8 @@ ____________ IntegrationTest.test_compileVariableCFF2[defcon-True] _____________ -self = -designspace = +self = +designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): @@ -1478,7 +1514,7 @@ tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -1515,8 +1551,8 @@ ____________ IntegrationTest.test_compileVariableCFF2[defcon-False] ____________ -self = -designspace = +self = +designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): @@ -1533,7 +1569,7 @@ tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -1570,8 +1606,8 @@ ________ IntegrationTest.test_compileVariableCFF2_subroutinized[defcon] ________ -self = -designspace = +self = +designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) @@ -1580,7 +1616,7 @@ tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -1617,8 +1653,8 @@ _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ -self = -designspace = +self = +designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @@ -1641,7 +1677,7 @@ tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -1678,8 +1714,8 @@ _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ -self = -designspace = +self = +designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @@ -1702,7 +1738,7 @@ tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -1739,8 +1775,8 @@ _______________ IntegrationTest.test_compileVariableTTFs[defcon] _______________ -self = -designspace_v5 = +self = +designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) @@ -1767,7 +1803,7 @@ tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -2055,8 +2091,8 @@ ______________ IntegrationTest.test_compileVariableCFF2s[defcon] _______________ -self = -designspace_v5 = +self = +designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) @@ -2083,7 +2119,7 @@ tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -2371,9 +2407,9 @@ _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableTTFs] ______ -self = +self = FontClass = -compileMethod = +compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] @@ -2390,7 +2426,7 @@ tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): @@ -2427,9 +2463,9 @@ _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableCFF2s] _____ -self = +self = FontClass = -compileMethod = +compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] @@ -2446,7 +2482,7 @@ tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): @@ -2498,7 +2534,7 @@ } dist; ''' -FontClass = .ctor at 0x7f2cd9daade0> +FontClass = .ctor at 0x7fdac8861620> def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a @@ -2530,7 +2566,7 @@ tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ -FontClass = .ctor at 0x7f2cd9daade0> +FontClass = .ctor at 0x7fdac8861620> def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a @@ -2670,8 +2706,8 @@ tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-None] _____________ -self = -designspace = +self = +designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): @@ -2686,7 +2722,7 @@ tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -2723,8 +2759,8 @@ ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-True] _____________ -self = -designspace = +self = +designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): @@ -2739,7 +2775,7 @@ tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -2776,8 +2812,8 @@ ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-False] ____________ -self = -designspace = +self = +designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): @@ -2792,7 +2828,7 @@ tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -2829,8 +2865,8 @@ ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-None] ____________ -self = -designspace = +self = +designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): @@ -2847,7 +2883,7 @@ tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -2884,8 +2920,8 @@ ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-True] ____________ -self = -designspace = +self = +designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): @@ -2902,7 +2938,7 @@ tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -2939,8 +2975,8 @@ ___________ IntegrationTest.test_compileVariableCFF2[ufoLib2-False] ____________ -self = -designspace = +self = +designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): @@ -2957,7 +2993,7 @@ tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -2994,8 +3030,8 @@ _______ IntegrationTest.test_compileVariableCFF2_subroutinized[ufoLib2] ________ -self = -designspace = +self = +designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) @@ -3004,7 +3040,7 @@ tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -3041,8 +3077,8 @@ _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ -self = -designspace = +self = +designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @@ -3065,7 +3101,7 @@ tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -3102,8 +3138,8 @@ _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ -self = -designspace = +self = +designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @@ -3126,7 +3162,7 @@ tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -3163,8 +3199,8 @@ ______________ IntegrationTest.test_compileVariableTTFs[ufoLib2] _______________ -self = -designspace_v5 = +self = +designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) @@ -3191,7 +3227,7 @@ tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -3479,8 +3515,8 @@ ______________ IntegrationTest.test_compileVariableCFF2s[ufoLib2] ______________ -self = -designspace_v5 = +self = +designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) @@ -3507,7 +3543,7 @@ tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -3795,9 +3831,9 @@ _____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableTTFs] _____ -self = -FontClass = .ctor at 0x7f2cd9daade0> -compileMethod = +self = +FontClass = .ctor at 0x7fdac8861620> +compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] @@ -3814,7 +3850,7 @@ tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): @@ -3851,9 +3887,9 @@ ____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableCFF2s] _____ -self = -FontClass = .ctor at 0x7f2cd9daade0> -compileMethod = +self = +FontClass = .ctor at 0x7fdac8861620> +compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] @@ -3870,7 +3906,7 @@ tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): @@ -3955,14 +3991,14 @@ FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableCFF2s] -====== 30 failed, 1102 passed, 8 skipped, 5 warnings in 112.45s (0:01:52) ====== +=========== 30 failed, 1102 passed, 8 skipped, 5 warnings in 23.50s ============ E: pybuild pybuild:389: test: plugin distutils failed with: exit code=1: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build; python3.13 -m pytest tests I: pybuild base:311: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build; python3.12 -m pytest tests ============================= test session starts ============================== platform linux -- Python 3.12.7, pytest-8.3.3, pluggy-1.5.0 rootdir: /build/reproducible-path/ufo2ft-3.3.1 configfile: setup.cfg -plugins: syrupy-4.7.2, typeguard-4.4.1 +plugins: typeguard-4.4.1, syrupy-4.7.2 collected 1140 items tests/featureCompiler_test.py ................ [ 1%] @@ -4226,8 +4262,8 @@ tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError _____________ IntegrationTest.test_compileVariableTTF[defcon-None] _____________ -self = -designspace = +self = +designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): @@ -4242,7 +4278,7 @@ tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -4279,8 +4315,8 @@ _____________ IntegrationTest.test_compileVariableTTF[defcon-True] _____________ -self = -designspace = +self = +designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): @@ -4295,7 +4331,7 @@ tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -4332,8 +4368,8 @@ ____________ IntegrationTest.test_compileVariableTTF[defcon-False] _____________ -self = -designspace = +self = +designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): @@ -4348,7 +4384,7 @@ tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -4385,8 +4421,8 @@ ____________ IntegrationTest.test_compileVariableCFF2[defcon-None] _____________ -self = -designspace = +self = +designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): @@ -4403,7 +4439,7 @@ tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -4440,8 +4476,8 @@ ____________ IntegrationTest.test_compileVariableCFF2[defcon-True] _____________ -self = -designspace = +self = +designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): @@ -4458,7 +4494,7 @@ tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -4495,8 +4531,8 @@ ____________ IntegrationTest.test_compileVariableCFF2[defcon-False] ____________ -self = -designspace = +self = +designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): @@ -4513,7 +4549,7 @@ tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -4550,8 +4586,8 @@ ________ IntegrationTest.test_compileVariableCFF2_subroutinized[defcon] ________ -self = -designspace = +self = +designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) @@ -4560,7 +4596,7 @@ tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -4597,8 +4633,8 @@ _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ -self = -designspace = +self = +designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @@ -4621,7 +4657,7 @@ tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -4658,8 +4694,8 @@ _ IntegrationTest.test_drop_glyph_names_variable[defcon-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ -self = -designspace = +self = +designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @@ -4682,7 +4718,7 @@ tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -4719,8 +4755,8 @@ _______________ IntegrationTest.test_compileVariableTTFs[defcon] _______________ -self = -designspace_v5 = +self = +designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) @@ -4747,7 +4783,7 @@ tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -5035,8 +5071,8 @@ ______________ IntegrationTest.test_compileVariableCFF2s[defcon] _______________ -self = -designspace_v5 = +self = +designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) @@ -5063,7 +5099,7 @@ tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -5351,9 +5387,9 @@ _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableTTFs] ______ -self = +self = FontClass = -compileMethod = +compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] @@ -5370,7 +5406,7 @@ tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): @@ -5407,9 +5443,9 @@ _____ IntegrationTest.test_apply_varfont_info[defcon-compileVariableCFF2s] _____ -self = +self = FontClass = -compileMethod = +compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] @@ -5426,7 +5462,7 @@ tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): @@ -5478,7 +5514,7 @@ } dist; ''' -FontClass = .ctor at 0x7ff561e9a020> +FontClass = .ctor at 0x7fd3b96b9620> def test_kern_zyyy_zinh(snapshot, FontClass): """Test that a sampling of glyphs with a common or inherited script, but a @@ -5510,7 +5546,7 @@ tests/featureWriters/kernFeatureWriter2_test.py:985: AssertionError _________________________ test_kern_zyyy_zinh[ufoLib2] _________________________ -FontClass = .ctor at 0x7ff561e9a020> +FontClass = .ctor at 0x7fd3b96b9620> def test_kern_zyyy_zinh(FontClass): """Test that a sampling of glyphs with a common or inherited script, but a @@ -5650,8 +5686,8 @@ tests/featureWriters/kernFeatureWriter_test.py:1805: AssertionError ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-None] _____________ -self = -designspace = +self = +designspace = useProductionNames = None def test_compileVariableTTF(self, designspace, useProductionNames): @@ -5666,7 +5702,7 @@ tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -5703,8 +5739,8 @@ ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-True] _____________ -self = -designspace = +self = +designspace = useProductionNames = True def test_compileVariableTTF(self, designspace, useProductionNames): @@ -5719,7 +5755,7 @@ tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -5756,8 +5792,8 @@ ____________ IntegrationTest.test_compileVariableTTF[ufoLib2-False] ____________ -self = -designspace = +self = +designspace = useProductionNames = False def test_compileVariableTTF(self, designspace, useProductionNames): @@ -5772,7 +5808,7 @@ tests/integration_test.py:232: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -5809,8 +5845,8 @@ ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-None] ____________ -self = -designspace = +self = +designspace = useProductionNames = None def test_compileVariableCFF2(self, designspace, useProductionNames): @@ -5827,7 +5863,7 @@ tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -5864,8 +5900,8 @@ ____________ IntegrationTest.test_compileVariableCFF2[ufoLib2-True] ____________ -self = -designspace = +self = +designspace = useProductionNames = True def test_compileVariableCFF2(self, designspace, useProductionNames): @@ -5882,7 +5918,7 @@ tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2-useProductionNames.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -5919,8 +5955,8 @@ ___________ IntegrationTest.test_compileVariableCFF2[ufoLib2-False] ____________ -self = -designspace = +self = +designspace = useProductionNames = False def test_compileVariableCFF2(self, designspace, useProductionNames): @@ -5937,7 +5973,7 @@ tests/integration_test.py:243: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -5974,8 +6010,8 @@ _______ IntegrationTest.test_compileVariableCFF2_subroutinized[ufoLib2] ________ -self = -designspace = +self = +designspace = def test_compileVariableCFF2_subroutinized(self, designspace): varfont = compileVariableCFF2(designspace, optimizeCFF=2) @@ -5984,7 +6020,7 @@ tests/integration_test.py:252: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2-cffsubr.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -6021,8 +6057,8 @@ _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableTTF-options0-TestVariableFont-TTF-post3.ttx] _ -self = -designspace = +self = +designspace = output_format = 'VariableTTF', options = {} expected_ttx = 'TestVariableFont-TTF-post3.ttx' @@ -6045,7 +6081,7 @@ tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-TTF-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -6082,8 +6118,8 @@ _ IntegrationTest.test_drop_glyph_names_variable[ufoLib2-VariableCFF2-options1-TestVariableFont-CFF2-post3.ttx] _ -self = -designspace = +self = +designspace = output_format = 'VariableCFF2', options = {} expected_ttx = 'TestVariableFont-CFF2-post3.ttx' @@ -6106,7 +6142,7 @@ tests/integration_test.py:303: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVariableFont-CFF2-post3.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -6143,8 +6179,8 @@ ______________ IntegrationTest.test_compileVariableTTFs[ufoLib2] _______________ -self = -designspace_v5 = +self = +designspace_v5 = def test_compileVariableTTFs(self, designspace_v5): fonts = compileVariableTTFs(designspace_v5) @@ -6171,7 +6207,7 @@ tests/integration_test.py:397: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-TTF.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -6459,8 +6495,8 @@ ______________ IntegrationTest.test_compileVariableCFF2s[ufoLib2] ______________ -self = -designspace_v5 = +self = +designspace_v5 = def test_compileVariableCFF2s(self, designspace_v5): fonts = compileVariableCFF2s(designspace_v5) @@ -6487,7 +6523,7 @@ tests/integration_test.py:434: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'DSv5/MutatorSansVariable_Weight_Width-CFF2.ttx', tables = None def expectTTX(font, expectedTTX, tables=None): @@ -6775,9 +6811,9 @@ _____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableTTFs] _____ -self = -FontClass = .ctor at 0x7ff561e9a020> -compileMethod = +self = +FontClass = .ctor at 0x7fd3b96b9620> +compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] @@ -6794,7 +6830,7 @@ tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): @@ -6831,9 +6867,9 @@ ____ IntegrationTest.test_apply_varfont_info[ufoLib2-compileVariableCFF2s] _____ -self = -FontClass = .ctor at 0x7ff561e9a020> -compileMethod = +self = +FontClass = .ctor at 0x7fd3b96b9620> +compileMethod = @pytest.mark.parametrize( "compileMethod", [compileVariableTTFs, compileVariableCFF2s] @@ -6850,7 +6886,7 @@ tests/integration_test.py:602: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ -font = +font = expectedTTX = 'TestVarFont-MyFontVF1.ttx', tables = ['head', 'name'] def expectTTX(font, expectedTTX, tables=None): @@ -6935,7 +6971,7 @@ FAILED tests/integration_test.py::IntegrationTest::test_compileVariableCFF2s[ufoLib2] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableTTFs] FAILED tests/integration_test.py::IntegrationTest::test_apply_varfont_info[ufoLib2-compileVariableCFF2s] -====== 30 failed, 1102 passed, 8 skipped, 5 warnings in 74.24s (0:01:14) ======= +=========== 30 failed, 1102 passed, 8 skipped, 5 warnings in 23.95s ============ E: pybuild pybuild:389: test: plugin distutils failed with: exit code=1: cd /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build; python3.12 -m pytest tests dh_auto_test: error: pybuild --test --test-pytest -i python{version} -p "3.13 3.12" returned exit code 13 make[1]: [debian/rules:15: override_dh_auto_test] Error 25 (ignored) @@ -6994,151 +7030,151 @@ running install_lib creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft -creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers -creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/baseCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableTTFCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/ttfCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableTTFsCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableOTFCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableCFF2sCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/otfCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft +creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters +creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/baseFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/ast.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter2.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/markFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/cursFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/gdefFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/cubicToQuadratic.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/propagateAnchors.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/explodeColorLayerGlyphs.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/transformations.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeTransformedComponents.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/reverseContourDirection.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/skipExportGlyphs.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/explodeColorLayerGlyphs.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/cubicToQuadratic.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircle.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/sortContours.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/removeOverlaps.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircleFilter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircle.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/base.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/transformations.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/removeOverlaps.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeComponents.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/flattenComponents.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/skipExportGlyphs.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeComponents.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__pycache__/reverseContourDirection.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters +creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers +creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/otfCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableCFF2sCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/ttfCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableTTFsCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableTTFCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableOTFCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__pycache__/baseCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/postProcessor.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/_version.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/constants.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/outlineCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/instantiator.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/infoCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/fontInfoData.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/util.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/instantiator.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/outlineCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/postProcessor.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/infoCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/featureCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/instructionCompiler.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/errors.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/preProcessor.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/_version.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft -creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters -creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/baseFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/gdefFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/cursFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/ast.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter2.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/markFeatureWriter.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/__pycache__/__init__.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__pycache__/errors.cpython-313.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/maxContextCalc.py to maxContextCalc.cpython-313.pyc +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.13_ufo2ft/build/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/preProcessor.py to preProcessor.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__init__.py to __init__.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__init__.py to __init__.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/interpolatableTTFCompiler.py to interpolatableTTFCompiler.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/baseCompiler.py to baseCompiler.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/ttfCompiler.py to ttfCompiler.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/interpolatableOTFCompiler.py to interpolatableOTFCompiler.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/variableCFF2sCompiler.py to variableCFF2sCompiler.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/otfCompiler.py to otfCompiler.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/variableTTFsCompiler.py to variableTTFsCompiler.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/constants.py to constants.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/outlineCompiler.py to outlineCompiler.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_version.py to _version.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__init__.py to __init__.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/removeOverlaps.py to removeOverlaps.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/kernFeatureWriter.py to kernFeatureWriter.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/markFeatureWriter.py to markFeatureWriter.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__main__.py to __main__.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/baseFeatureWriter.py to baseFeatureWriter.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__init__.py to __init__.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/cursFeatureWriter.py to cursFeatureWriter.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/kernFeatureWriter2.py to kernFeatureWriter2.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/gdefFeatureWriter.py to gdefFeatureWriter.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/ast.py to ast.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/base.py to base.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/decomposeComponents.py to decomposeComponents.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/sortContours.py to sortContours.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/skipExportGlyphs.py to skipExportGlyphs.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/reverseContourDirection.py to reverseContourDirection.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/explodeColorLayerGlyphs.py to explodeColorLayerGlyphs.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/decomposeTransformedComponents.py to decomposeTransformedComponents.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/flattenComponents.py to flattenComponents.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/dottedCircleFilter.py to dottedCircleFilter.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/base.py to base.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__main__.py to __main__.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/decomposeComponents.py to decomposeComponents.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/transformations.py to transformations.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/dottedCircle.py to dottedCircle.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/removeOverlaps.py to removeOverlaps.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/cubicToQuadratic.py to cubicToQuadratic.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/sortContours.py to sortContours.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/dottedCircleFilter.py to dottedCircleFilter.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/propagateAnchors.py to propagateAnchors.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/infoCompiler.py to infoCompiler.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/reverseContourDirection.py to reverseContourDirection.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/decomposeTransformedComponents.py to decomposeTransformedComponents.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/transformations.py to transformations.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/explodeColorLayerGlyphs.py to explodeColorLayerGlyphs.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/filters/dottedCircle.py to dottedCircle.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/otfCompiler.py to otfCompiler.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/interpolatableTTFCompiler.py to interpolatableTTFCompiler.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/ttfCompiler.py to ttfCompiler.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/baseCompiler.py to baseCompiler.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/variableCFF2sCompiler.py to variableCFF2sCompiler.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/variableTTFsCompiler.py to variableTTFsCompiler.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/interpolatableOTFCompiler.py to interpolatableOTFCompiler.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_compilers/__init__.py to __init__.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/fontInfoData.py to fontInfoData.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/instantiator.py to instantiator.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/errors.py to errors.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/postProcessor.py to postProcessor.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureCompiler.py to featureCompiler.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/_version.py to _version.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/instructionCompiler.py to instructionCompiler.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__init__.py to __init__.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/kernFeatureWriter2.py to kernFeatureWriter2.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/baseFeatureWriter.py to baseFeatureWriter.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/ast.py to ast.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/cursFeatureWriter.py to cursFeatureWriter.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/gdefFeatureWriter.py to gdefFeatureWriter.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/__main__.py to __main__.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/markFeatureWriter.py to markFeatureWriter.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureWriters/kernFeatureWriter.py to kernFeatureWriter.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/__init__.py to __init__.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/constants.py to constants.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/maxContextCalc.py to maxContextCalc.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/outlineCompiler.py to outlineCompiler.cpython-313.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/infoCompiler.py to infoCompiler.cpython-313.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/util.py to util.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/errors.py to errors.cpython-313.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft/featureCompiler.py to featureCompiler.cpython-313.pyc running install_egg_info Copying Lib/ufo2ft.egg-info to /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.13/dist-packages/ufo2ft-3.3.1.egg-info Skipping SOURCES.txt @@ -7191,151 +7227,151 @@ running install_lib creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/preProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft -creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers -creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/otfCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableTTFsCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableOTFCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/ttfCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableTTFCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableCFF2sCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/baseCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft +creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters +creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/gdefFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/markFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/baseFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter2.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/cursFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/ast.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/skipExportGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/flattenComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/base.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/explodeColorLayerGlyphs.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircle.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/cubicToQuadratic.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeTransformedComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/removeOverlaps.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/propagateAnchors.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/base.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/flattenComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/reverseContourDirection.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/removeOverlaps.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircle.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/skipExportGlyphs.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/explodeColorLayerGlyphs.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/transformations.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/sortContours.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/skipExportGlyphs.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/base.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/dottedCircleFilter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/decomposeComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/decomposeTransformedComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__pycache__/flattenComponents.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/removeOverlaps.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/cubicToQuadratic.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/sortContours.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/dottedCircleFilter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/propagateAnchors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/reverseContourDirection.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/decomposeTransformedComponents.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/transformations.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/explodeColorLayerGlyphs.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/filters/dottedCircle.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters +creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/otfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/interpolatableTTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/ttfCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers +creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableTTFsCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/baseCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableOTFCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/interpolatableTTFCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/ttfCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/otfCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__pycache__/variableCFF2sCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/baseCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/variableCFF2sCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/variableTTFsCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/interpolatableOTFCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_compilers/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/fontInfoData.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/instantiator.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/constants.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/fontInfoData.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/instructionCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/outlineCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/util.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/preProcessor.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/errors.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/postProcessor.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/infoCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/instructionCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/fontInfoData.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/_version.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/postProcessor.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/featureCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/instantiator.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/constants.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/util.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft -creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter2.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/baseFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/ast.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/cursFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/gdefFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__main__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters -creating /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter2.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/markFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/__init__.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/ast.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/gdefFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/baseFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/kernFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/__pycache__/cursFeatureWriter.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__pycache__ -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/markFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureWriters/kernFeatureWriter.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters -copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/errors.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/infoCompiler.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__pycache__/preProcessor.cpython-312.pyc -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__pycache__ +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/instantiator.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/errors.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/postProcessor.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/featureCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/maxContextCalc.py to maxContextCalc.cpython-312.pyc +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/_version.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/instructionCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/__init__.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/constants.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/maxContextCalc.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/outlineCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/infoCompiler.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft +copying /build/reproducible-path/ufo2ft-3.3.1/.pybuild/cpython3_3.12_ufo2ft/build/ufo2ft/util.py -> /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/preProcessor.py to preProcessor.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__init__.py to __init__.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__init__.py to __init__.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/interpolatableTTFCompiler.py to interpolatableTTFCompiler.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/baseCompiler.py to baseCompiler.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/ttfCompiler.py to ttfCompiler.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/interpolatableOTFCompiler.py to interpolatableOTFCompiler.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/variableCFF2sCompiler.py to variableCFF2sCompiler.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/otfCompiler.py to otfCompiler.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/variableTTFsCompiler.py to variableTTFsCompiler.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/constants.py to constants.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/outlineCompiler.py to outlineCompiler.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_version.py to _version.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__init__.py to __init__.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/removeOverlaps.py to removeOverlaps.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/kernFeatureWriter.py to kernFeatureWriter.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/markFeatureWriter.py to markFeatureWriter.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__main__.py to __main__.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/baseFeatureWriter.py to baseFeatureWriter.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__init__.py to __init__.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/cursFeatureWriter.py to cursFeatureWriter.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/kernFeatureWriter2.py to kernFeatureWriter2.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/gdefFeatureWriter.py to gdefFeatureWriter.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/ast.py to ast.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/base.py to base.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/decomposeComponents.py to decomposeComponents.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/sortContours.py to sortContours.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/skipExportGlyphs.py to skipExportGlyphs.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/reverseContourDirection.py to reverseContourDirection.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/explodeColorLayerGlyphs.py to explodeColorLayerGlyphs.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/decomposeTransformedComponents.py to decomposeTransformedComponents.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/flattenComponents.py to flattenComponents.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/dottedCircleFilter.py to dottedCircleFilter.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/base.py to base.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__main__.py to __main__.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/decomposeComponents.py to decomposeComponents.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/transformations.py to transformations.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/dottedCircle.py to dottedCircle.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/removeOverlaps.py to removeOverlaps.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/cubicToQuadratic.py to cubicToQuadratic.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/sortContours.py to sortContours.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/dottedCircleFilter.py to dottedCircleFilter.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/propagateAnchors.py to propagateAnchors.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/infoCompiler.py to infoCompiler.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/reverseContourDirection.py to reverseContourDirection.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/decomposeTransformedComponents.py to decomposeTransformedComponents.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/transformations.py to transformations.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/explodeColorLayerGlyphs.py to explodeColorLayerGlyphs.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/filters/dottedCircle.py to dottedCircle.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/otfCompiler.py to otfCompiler.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/interpolatableTTFCompiler.py to interpolatableTTFCompiler.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/ttfCompiler.py to ttfCompiler.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/baseCompiler.py to baseCompiler.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/variableCFF2sCompiler.py to variableCFF2sCompiler.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/variableTTFsCompiler.py to variableTTFsCompiler.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/interpolatableOTFCompiler.py to interpolatableOTFCompiler.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_compilers/__init__.py to __init__.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/fontInfoData.py to fontInfoData.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/instantiator.py to instantiator.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/errors.py to errors.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/postProcessor.py to postProcessor.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureCompiler.py to featureCompiler.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/_version.py to _version.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/instructionCompiler.py to instructionCompiler.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__init__.py to __init__.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/kernFeatureWriter2.py to kernFeatureWriter2.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/baseFeatureWriter.py to baseFeatureWriter.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/ast.py to ast.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/cursFeatureWriter.py to cursFeatureWriter.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/gdefFeatureWriter.py to gdefFeatureWriter.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/__main__.py to __main__.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/markFeatureWriter.py to markFeatureWriter.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureWriters/kernFeatureWriter.py to kernFeatureWriter.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/__init__.py to __init__.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/constants.py to constants.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/maxContextCalc.py to maxContextCalc.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/outlineCompiler.py to outlineCompiler.cpython-312.pyc +byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/infoCompiler.py to infoCompiler.cpython-312.pyc byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/util.py to util.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/errors.py to errors.cpython-312.pyc -byte-compiling /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft/featureCompiler.py to featureCompiler.cpython-312.pyc running install_egg_info Copying Lib/ufo2ft.egg-info to /build/reproducible-path/ufo2ft-3.3.1/debian/python3-ufo2ft/usr/lib/python3.12/dist-packages/ufo2ft-3.3.1.egg-info Skipping SOURCES.txt @@ -7362,12 +7398,14 @@ dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: not including original source code in upload I: copying local configuration +I: user script /srv/workspace/pbuilder/501244/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/501244/tmp/hooks/B01_cleanup finished I: unmounting dev/ptmx filesystem I: unmounting dev/pts filesystem I: unmounting dev/shm filesystem I: unmounting proc filesystem I: unmounting sys filesystem I: cleaning the build env -I: removing directory /srv/workspace/pbuilder/894615 and its subdirectories -I: Current time: Sun Nov 24 07:33:14 -12 2024 -I: pbuilder-time-stamp: 1732476794 +I: removing directory /srv/workspace/pbuilder/501244 and its subdirectories +I: Current time: Sun Dec 28 15:58:27 +14 2025 +I: pbuilder-time-stamp: 1766887107 Compressing the 2nd log... /var/lib/jenkins/userContent/reproducible/debian/logdiffs/unstable/amd64/ufo2ft_3.3.1-2.diff: 93.6% -- replaced with /var/lib/jenkins/userContent/reproducible/debian/logdiffs/unstable/amd64/ufo2ft_3.3.1-2.diff.gz b2/build.log: 90.6% -- replaced with stdout Compressing the 1st log... b1/build.log: 90.7% -- replaced with stdout Sun Nov 24 19:35:30 UTC 2024 I: diffoscope 283 will be used to compare the two builds: ++ date -u +%s + DIFFOSCOPE_STAMP=/var/log/reproducible-builds/diffoscope_stamp_ufo2ft_unstable_amd64_1732476930 + touch /var/log/reproducible-builds/diffoscope_stamp_ufo2ft_unstable_amd64_1732476930 + RESULT=0 + systemd-run '--description=diffoscope on ufo2ft/3.3.1-2 in unstable/amd64' --slice=rb-build-diffoscope.slice -u rb-diffoscope-amd64_7-40090 '--property=SuccessExitStatus=1 124' --user --send-sighup --pipe --wait -E TMPDIR timeout 155m nice schroot --directory /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf --run-session -c jenkins-reproducible-unstable-diffoscope-822e72fd-9437-4996-9588-9b5cca2e4920 -- sh -c 'export TMPDIR=/srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/dbd-tmp-XE3jNtP ; timeout 150m diffoscope --timeout 7200 --html /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/ufo2ft_3.3.1-2.diffoscope.html --text /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/ufo2ft_3.3.1-2.diffoscope.txt --json /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/ufo2ft_3.3.1-2.diffoscope.json --profile=- /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b1/ufo2ft_3.3.1-2_amd64.changes /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b2/ufo2ft_3.3.1-2_amd64.changes' + false + set +x Running as unit: rb-diffoscope-amd64_7-40090.service # Profiling output for: /usr/bin/diffoscope --timeout 7200 --html /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/ufo2ft_3.3.1-2.diffoscope.html --text /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/ufo2ft_3.3.1-2.diffoscope.txt --json /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/ufo2ft_3.3.1-2.diffoscope.json --profile=- /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b1/ufo2ft_3.3.1-2_amd64.changes /srv/reproducible-results/rbuild-debian/r-b-build.ehFZPKYf/b2/ufo2ft_3.3.1-2_amd64.changes ## command (total time: 0.000s) 0.000s 1 call cmp (internal) ## has_same_content_as (total time: 0.000s) 0.000s 1 call abc.DotChangesFile ## main (total time: 0.324s) 0.324s 2 calls outputs 0.000s 1 call cleanup ## recognizes (total time: 0.015s) 0.015s 12 calls diffoscope.comparators.binary.FilesystemFile ## specialize (total time: 0.000s) 0.000s 1 call specialize Finished with result: success Main processes terminated with: code=exited/status=0 Service runtime: 648ms CPU time consumed: 649ms __ ____ __ _ _ _ / _| ___|___ \ / _| |_ | | | | |_ / _ \ __) | |_| __| | |_| | _| (_) / __/| _| |_ \__,_|_| \___/_____|_| \__| Sun Nov 24 19:57:55 UTC 2024 I: diffoscope 283 found no differences in the changes files, and a .buildinfo file also exists. Sun Nov 24 19:57:55 UTC 2024 I: ufo2ft from unstable built successfully and reproducibly on amd64. INSERT 0 1 INSERT 0 1 DELETE 1 [2024-11-24 19:57:56] INFO: Starting at 2024-11-24 19:57:56.739678 [2024-11-24 19:57:56] INFO: Generating the pages of 1 package(s) [2024-11-24 19:57:57] CRITICAL: https://tests.reproducible-builds.org/debian/unstable/amd64/ufo2ft didn't produce a buildlog, even though it has been built. [2024-11-24 19:57:57] INFO: Finished at 2024-11-24 19:57:57.572030, took: 0:00:00.832360 Sun Nov 24 19:57:57 UTC 2024 - successfully updated the database and updated https://tests.reproducible-builds.org/debian/rb-pkg/unstable/amd64/ufo2ft.html Sun Nov 24 19:57:57 UTC 2024 I: Submitting .buildinfo files to external archives: Sun Nov 24 19:57:57 UTC 2024 I: Submitting 8.0K b1/ufo2ft_3.3.1-2_amd64.buildinfo.asc https://buildinfo.debian.net/9c999b69bef67479fe7d9027cba52ec6cb864a85/ufo2ft_3.3.1-2_all Sun Nov 24 19:58:17 UTC 2024 I: Submitting 8.0K b2/ufo2ft_3.3.1-2_amd64.buildinfo.asc https://buildinfo.debian.net/26e480746234201df93cfa0b555197ad4c3bd36f/ufo2ft_3.3.1-2_all Sun Nov 24 19:58:46 UTC 2024 I: Done submitting .buildinfo files to http://buildinfo.debian.net/api/submit. Sun Nov 24 19:58:46 UTC 2024 I: Done submitting .buildinfo files. Sun Nov 24 19:58:46 UTC 2024 I: Removing signed ufo2ft_3.3.1-2_amd64.buildinfo.asc files: removed './b1/ufo2ft_3.3.1-2_amd64.buildinfo.asc' removed './b2/ufo2ft_3.3.1-2_amd64.buildinfo.asc' 1732478326 amd64 unstable ufo2ft Starting cleanup. /var/lib/jenkins/userContent/reproducible/debian/rbuild/unstable/amd64/ufo2ft_3.3.1-2.rbuild.log: 90.1% -- replaced with /var/lib/jenkins/userContent/reproducible/debian/rbuild/unstable/amd64/ufo2ft_3.3.1-2.rbuild.log.gz [2024-11-24 19:58:47] INFO: Starting at 2024-11-24 19:58:47.169255 [2024-11-24 19:58:47] INFO: Generating the pages of 1 package(s) [2024-11-24 19:58:47] INFO: Finished at 2024-11-24 19:58:47.728068, took: 0:00:00.558820 All cleanup done. Sun Nov 24 19:58:48 UTC 2024 - total duration: 0h 35m 27s. Sun Nov 24 19:58:48 UTC 2024 - reproducible_build.sh stopped running as /tmp/jenkins-script-e2riV8WR, removing. Finished with result: success Main processes terminated with: code=exited/status=0 Service runtime: 36min 20.115s CPU time consumed: 8.836s