Diff of the two buildlogs:

--
--- b1/build.log	2025-02-16 08:39:26.025502892 +0000
+++ b2/build.log	2025-02-16 08:43:44.661832092 +0000
@@ -1,6 +1,6 @@
 I: pbuilder: network access will be disabled during build
-I: Current time: Sat Feb 15 20:31:05 -12 2025
-I: pbuilder-time-stamp: 1739694665
+I: Current time: Sun Mar 22 05:02:26 +14 2026
+I: pbuilder-time-stamp: 1774105346
 I: Building the build Environment
 I: extracting base tarball [/var/cache/pbuilder/trixie-reproducible-base.tgz]
 I: copying local configuration
@@ -22,52 +22,84 @@
 dpkg-source: info: unpacking python-osc-placement_4.5.0-3.debian.tar.xz
 I: using fakeroot in build.
 I: Installing the build-deps
-I: user script /srv/workspace/pbuilder/2793814/tmp/hooks/D02_print_environment starting
+I: user script /srv/workspace/pbuilder/3629279/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 Mar 21 15:02 /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/3629279/tmp/hooks/D01_modify_environment finished
+I: user script /srv/workspace/pbuilder/3629279/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='trixie'
-  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]="37" [3]="1" [4]="release" [5]="x86_64-pc-linux-gnu")
+  BASH_VERSION='5.2.37(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=trixie
+  EUID=0
+  FUNCNAME=([0]="Echo" [1]="main")
+  GROUPS=()
+  HOME=/root
+  HOSTNAME=i-capture-the-hostname
+  HOSTTYPE=x86_64
+  HOST_ARCH=amd64
   IFS=' 	
   '
-  INVOCATION_ID='142a1e04477c43caa453175952961f1b'
-  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='2793814'
-  PS1='# '
-  PS2='> '
+  INVOCATION_ID=1e5c662599174b3c9de536651f065497
+  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=3629279
   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.0rr8lrLQ/pbuilderrc_CWP1 --distribution trixie --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/trixie-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.0rr8lrLQ/b1 --logfile b1/build.log python-osc-placement_4.5.0-3.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.0rr8lrLQ/pbuilderrc_rLcl --distribution trixie --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/trixie-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.0rr8lrLQ/b2 --logfile b2/build.log python-osc-placement_4.5.0-3.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-31-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.128-1 (2025-02-07) x86_64 GNU/Linux
+  Linux i-capture-the-hostname 6.12.9+bpo-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.12.9-1~bpo12+1 (2025-01-19) 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/2793814/tmp/hooks/D02_print_environment finished
+  lrwxrwxrwx 1 root root 7 Nov 22  2024 /bin -> usr/bin
+I: user script /srv/workspace/pbuilder/3629279/tmp/hooks/D02_print_environment finished
  -> Attempting to satisfy build-dependencies
  -> Creating pbuilder-satisfydepends-dummy package
 Package: pbuilder-satisfydepends-dummy
@@ -384,7 +416,7 @@
 Get: 237 http://deb.debian.org/debian trixie/main amd64 python3-reno all 4.1.0-2 [44.2 kB]
 Get: 238 http://deb.debian.org/debian trixie/main amd64 python3-sphinx-feature-classification all 2.0.0-2 [8980 B]
 Get: 239 http://deb.debian.org/debian trixie/main amd64 python3-wsgi-intercept all 1.13.1-1 [18.9 kB]
-Fetched 80.5 MB in 20s (4118 kB/s)
+Fetched 80.5 MB in 2s (53.2 MB/s)
 Preconfiguring packages ...
 Selecting previously unselected package libpython3.13-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 ... 19808 files and directories currently installed.)
@@ -1151,8 +1183,8 @@
 Setting up tzdata (2024b-6) ...
 
 Current default time zone: 'Etc/UTC'
-Local time is now:      Sun Feb 16 08:35:31 UTC 2025.
-Universal Time is now:  Sun Feb 16 08:35:31 UTC 2025.
+Local time is now:      Sat Mar 21 15:04:36 UTC 2026.
+Universal Time is now:  Sat Mar 21 15:04:36 UTC 2026.
 Run 'dpkg-reconfigure tzdata' if you wish to change it.
 
 Setting up liberror-perl (0.17029-2) ...
@@ -1387,7 +1419,11 @@
 fakeroot is already the newest version (1.37-1).
 0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
 I: Building the package
-I: Running cd /build/reproducible-path/python-osc-placement-4.5.0/ && 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  > ../python-osc-placement_4.5.0-3_source.changes
+I: user script /srv/workspace/pbuilder/3629279/tmp/hooks/A99_set_merged_usr starting
+Not re-configuring usrmerge for trixie
+I: user script /srv/workspace/pbuilder/3629279/tmp/hooks/A99_set_merged_usr finished
+hostname: Name or service not known
+I: Running cd /build/reproducible-path/python-osc-placement-4.5.0/ && 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  > ../python-osc-placement_4.5.0-3_source.changes
 dpkg-buildpackage: info: source package python-osc-placement
 dpkg-buildpackage: info: source version 4.5.0-3
 dpkg-buildpackage: info: source distribution unstable
@@ -1525,21 +1561,26 @@
 py3versions: no X-Python3-Version in control file, using supported versions
 pkgos-dh_auto_install --no-py2 --in-tmp
 + PKGOS_IN_TMP=no
-+ echo WARNING: --no-py2 is deprecated and always on.
++ for i in $@
++ case "${1}" in
++ echo 'WARNING: --no-py2 is deprecated and always on.'
 WARNING: --no-py2 is deprecated and always on.
 + shift
++ for i in $@
++ case "${1}" in
 + PKGOS_IN_TMP=yes
 + shift
-+ dpkg-parsechangelog -SSource
+++ dpkg-parsechangelog -SSource
 + SRC_PKG_NAME=python-osc-placement
-+ echo+ sed s/python-//
- python-osc-placement
+++ echo python-osc-placement
+++ sed s/python-//
 + PY_MODULE_NAME=osc-placement
-+ py3versions -vr
-+ PYTHON3S=3.12 3.13
-+ [ yes = yes ]
+++ py3versions -vr
++ PYTHON3S='3.12 3.13'
++ '[' yes = yes ']'
 + TARGET_DIR=tmp
-+ pwd
++ for pyvers in ${PYTHON3S}
+++ pwd
 + python3.12 setup.py install --install-layout=deb --root /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp
 /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated.
 !!
@@ -1587,39 +1628,39 @@
 creating build/lib/osc_placement/tests
 copying osc_placement/tests/__init__.py -> build/lib/osc_placement/tests
 creating build/lib/osc_placement/tests/unit
-copying osc_placement/tests/unit/__init__.py -> build/lib/osc_placement/tests/unit
 copying osc_placement/tests/unit/test_http.py -> build/lib/osc_placement/tests/unit
-copying osc_placement/tests/unit/test_plugin.py -> build/lib/osc_placement/tests/unit
 copying osc_placement/tests/unit/test_common.py -> build/lib/osc_placement/tests/unit
-copying osc_placement/tests/unit/test_allocation.py -> build/lib/osc_placement/tests/unit
 copying osc_placement/tests/unit/test_version.py -> build/lib/osc_placement/tests/unit
+copying osc_placement/tests/unit/test_plugin.py -> build/lib/osc_placement/tests/unit
+copying osc_placement/tests/unit/test_allocation.py -> build/lib/osc_placement/tests/unit
+copying osc_placement/tests/unit/__init__.py -> build/lib/osc_placement/tests/unit
+creating build/lib/osc_placement/tests/functional
+copying osc_placement/tests/functional/base.py -> build/lib/osc_placement/tests/functional
+copying osc_placement/tests/functional/test_resource_provider.py -> build/lib/osc_placement/tests/functional
+copying osc_placement/tests/functional/test_trait.py -> build/lib/osc_placement/tests/functional
+copying osc_placement/tests/functional/test_allocation_candidate.py -> build/lib/osc_placement/tests/functional
+copying osc_placement/tests/functional/test_usage.py -> build/lib/osc_placement/tests/functional
+copying osc_placement/tests/functional/test_inventory.py -> build/lib/osc_placement/tests/functional
+copying osc_placement/tests/functional/test_plugin.py -> build/lib/osc_placement/tests/functional
+copying osc_placement/tests/functional/test_allocation.py -> build/lib/osc_placement/tests/functional
+copying osc_placement/tests/functional/__init__.py -> build/lib/osc_placement/tests/functional
+copying osc_placement/tests/functional/test_aggregate.py -> build/lib/osc_placement/tests/functional
+copying osc_placement/tests/functional/test_resource_class.py -> build/lib/osc_placement/tests/functional
 creating build/lib/osc_placement/resources
-copying osc_placement/resources/__init__.py -> build/lib/osc_placement/resources
+copying osc_placement/resources/common.py -> build/lib/osc_placement/resources
 copying osc_placement/resources/inventory.py -> build/lib/osc_placement/resources
+copying osc_placement/resources/resource_class.py -> build/lib/osc_placement/resources
 copying osc_placement/resources/usage.py -> build/lib/osc_placement/resources
-copying osc_placement/resources/allocation.py -> build/lib/osc_placement/resources
-copying osc_placement/resources/allocation_candidate.py -> build/lib/osc_placement/resources
-copying osc_placement/resources/common.py -> build/lib/osc_placement/resources
+copying osc_placement/resources/__init__.py -> build/lib/osc_placement/resources
 copying osc_placement/resources/aggregate.py -> build/lib/osc_placement/resources
+copying osc_placement/resources/allocation.py -> build/lib/osc_placement/resources
 copying osc_placement/resources/trait.py -> build/lib/osc_placement/resources
 copying osc_placement/resources/resource_provider.py -> build/lib/osc_placement/resources
-copying osc_placement/resources/resource_class.py -> build/lib/osc_placement/resources
-copying osc_placement/__init__.py -> build/lib/osc_placement
+copying osc_placement/resources/allocation_candidate.py -> build/lib/osc_placement/resources
+copying osc_placement/version.py -> build/lib/osc_placement
 copying osc_placement/plugin.py -> build/lib/osc_placement
+copying osc_placement/__init__.py -> build/lib/osc_placement
 copying osc_placement/http.py -> build/lib/osc_placement
-copying osc_placement/version.py -> build/lib/osc_placement
-creating build/lib/osc_placement/tests/functional
-copying osc_placement/tests/functional/__init__.py -> build/lib/osc_placement/tests/functional
-copying osc_placement/tests/functional/test_usage.py -> build/lib/osc_placement/tests/functional
-copying osc_placement/tests/functional/test_resource_provider.py -> build/lib/osc_placement/tests/functional
-copying osc_placement/tests/functional/test_resource_class.py -> build/lib/osc_placement/tests/functional
-copying osc_placement/tests/functional/test_trait.py -> build/lib/osc_placement/tests/functional
-copying osc_placement/tests/functional/test_aggregate.py -> build/lib/osc_placement/tests/functional
-copying osc_placement/tests/functional/test_plugin.py -> build/lib/osc_placement/tests/functional
-copying osc_placement/tests/functional/test_inventory.py -> build/lib/osc_placement/tests/functional
-copying osc_placement/tests/functional/base.py -> build/lib/osc_placement/tests/functional
-copying osc_placement/tests/functional/test_allocation_candidate.py -> build/lib/osc_placement/tests/functional
-copying osc_placement/tests/functional/test_allocation.py -> build/lib/osc_placement/tests/functional
 running egg_info
 creating osc_placement.egg-info
 writing osc_placement.egg-info/PKG-INFO
@@ -1645,79 +1686,80 @@
 running install_lib
 creating /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages
 creating /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement
-copying build/lib/osc_placement/__init__.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement
-creating /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
-copying build/lib/osc_placement/resources/__init__.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
-copying build/lib/osc_placement/resources/inventory.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
-copying build/lib/osc_placement/resources/usage.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
-copying build/lib/osc_placement/resources/allocation.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
-copying build/lib/osc_placement/resources/allocation_candidate.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
-copying build/lib/osc_placement/resources/common.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
-copying build/lib/osc_placement/resources/aggregate.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
-copying build/lib/osc_placement/resources/trait.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
-copying build/lib/osc_placement/resources/resource_provider.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
-copying build/lib/osc_placement/resources/resource_class.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
-copying build/lib/osc_placement/plugin.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement
+copying build/lib/osc_placement/version.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement
 creating /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests
-copying build/lib/osc_placement/tests/__init__.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests
 creating /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit
-copying build/lib/osc_placement/tests/unit/__init__.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit
 copying build/lib/osc_placement/tests/unit/test_http.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit
-copying build/lib/osc_placement/tests/unit/test_plugin.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit
 copying build/lib/osc_placement/tests/unit/test_common.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit
-copying build/lib/osc_placement/tests/unit/test_allocation.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit
 copying build/lib/osc_placement/tests/unit/test_version.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit
+copying build/lib/osc_placement/tests/unit/test_plugin.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit
+copying build/lib/osc_placement/tests/unit/test_allocation.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit
+copying build/lib/osc_placement/tests/unit/__init__.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit
 creating /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
-copying build/lib/osc_placement/tests/functional/__init__.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
-copying build/lib/osc_placement/tests/functional/test_usage.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
+copying build/lib/osc_placement/tests/functional/base.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
 copying build/lib/osc_placement/tests/functional/test_resource_provider.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
-copying build/lib/osc_placement/tests/functional/test_resource_class.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
 copying build/lib/osc_placement/tests/functional/test_trait.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
-copying build/lib/osc_placement/tests/functional/test_aggregate.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
-copying build/lib/osc_placement/tests/functional/test_plugin.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
-copying build/lib/osc_placement/tests/functional/test_inventory.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
-copying build/lib/osc_placement/tests/functional/base.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
 copying build/lib/osc_placement/tests/functional/test_allocation_candidate.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
+copying build/lib/osc_placement/tests/functional/test_usage.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
+copying build/lib/osc_placement/tests/functional/test_inventory.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
+copying build/lib/osc_placement/tests/functional/test_plugin.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
 copying build/lib/osc_placement/tests/functional/test_allocation.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
+copying build/lib/osc_placement/tests/functional/__init__.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
+copying build/lib/osc_placement/tests/functional/test_aggregate.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
+copying build/lib/osc_placement/tests/functional/test_resource_class.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional
+copying build/lib/osc_placement/tests/__init__.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests
+copying build/lib/osc_placement/plugin.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement
+copying build/lib/osc_placement/__init__.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement
 copying build/lib/osc_placement/http.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement
-copying build/lib/osc_placement/version.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/__init__.py to __init__.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/__init__.py to __init__.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/inventory.py to inventory.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/usage.py to usage.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/allocation.py to allocation.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/allocation_candidate.py to allocation_candidate.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/common.py to common.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/aggregate.py to aggregate.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/trait.py to trait.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/resource_provider.py to resource_provider.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/resource_class.py to resource_class.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/plugin.py to plugin.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/__init__.py to __init__.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/__init__.py to __init__.cpython-312.pyc
+creating /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
+copying build/lib/osc_placement/resources/common.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
+copying build/lib/osc_placement/resources/inventory.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
+copying build/lib/osc_placement/resources/resource_class.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
+copying build/lib/osc_placement/resources/usage.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
+copying build/lib/osc_placement/resources/__init__.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
+copying build/lib/osc_placement/resources/aggregate.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
+copying build/lib/osc_placement/resources/allocation.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
+copying build/lib/osc_placement/resources/trait.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
+copying build/lib/osc_placement/resources/resource_provider.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
+copying build/lib/osc_placement/resources/allocation_candidate.py -> /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/version.py to version.cpython-312.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_http.py to test_http.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_plugin.py to test_plugin.cpython-312.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_common.py to test_common.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_allocation.py to test_allocation.cpython-312.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_version.py to test_version.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/__init__.py to __init__.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_usage.py to test_usage.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_plugin.py to test_plugin.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_allocation.py to test_allocation.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/__init__.py to __init__.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/base.py to base.cpython-312.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_resource_provider.py to test_resource_provider.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_resource_class.py to test_resource_class.cpython-312.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_trait.py to test_trait.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_aggregate.py to test_aggregate.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_plugin.py to test_plugin.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_inventory.py to test_inventory.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/base.py to base.cpython-312.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_allocation_candidate.py to test_allocation_candidate.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_usage.py to test_usage.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_inventory.py to test_inventory.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_plugin.py to test_plugin.cpython-312.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_allocation.py to test_allocation.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/__init__.py to __init__.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_aggregate.py to test_aggregate.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_resource_class.py to test_resource_class.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/__init__.py to __init__.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/plugin.py to plugin.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/__init__.py to __init__.cpython-312.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/http.py to http.cpython-312.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/version.py to version.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/common.py to common.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/inventory.py to inventory.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/resource_class.py to resource_class.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/usage.py to usage.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/__init__.py to __init__.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/aggregate.py to aggregate.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/allocation.py to allocation.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/trait.py to trait.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/resource_provider.py to resource_provider.cpython-312.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/allocation_candidate.py to allocation_candidate.cpython-312.pyc
 running install_egg_info
 Copying osc_placement.egg-info to /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement-4.5.0.egg-info
 Skipping SOURCES.txt
 running install_scripts
-+ pwd
++ for pyvers in ${PYTHON3S}
+++ pwd
 + python3.13 setup.py install --install-layout=deb --root /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp
 /usr/lib/python3/dist-packages/setuptools/__init__.py:94: _DeprecatedInstaller: setuptools.installer and fetch_build_eggs are deprecated.
 !!
@@ -1770,47 +1812,47 @@
 writing top-level names to osc_placement.egg-info/top_level.txt
 [pbr] Reusing existing SOURCES.txt
 running install_lib
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/__init__.py to __init__.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/__init__.py to __init__.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/inventory.py to inventory.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/usage.py to usage.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/allocation.py to allocation.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/allocation_candidate.py to allocation_candidate.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/common.py to common.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/aggregate.py to aggregate.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/trait.py to trait.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/resource_provider.py to resource_provider.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/resource_class.py to resource_class.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/plugin.py to plugin.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/__init__.py to __init__.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/__init__.py to __init__.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/version.py to version.cpython-313.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_http.py to test_http.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_plugin.py to test_plugin.cpython-313.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_common.py to test_common.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_allocation.py to test_allocation.cpython-313.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_version.py to test_version.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/__init__.py to __init__.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_usage.py to test_usage.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_plugin.py to test_plugin.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/test_allocation.py to test_allocation.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/unit/__init__.py to __init__.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/base.py to base.cpython-313.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_resource_provider.py to test_resource_provider.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_resource_class.py to test_resource_class.cpython-313.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_trait.py to test_trait.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_aggregate.py to test_aggregate.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_plugin.py to test_plugin.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_inventory.py to test_inventory.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/base.py to base.cpython-313.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_allocation_candidate.py to test_allocation_candidate.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_usage.py to test_usage.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_inventory.py to test_inventory.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_plugin.py to test_plugin.cpython-313.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_allocation.py to test_allocation.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/__init__.py to __init__.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_aggregate.py to test_aggregate.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/functional/test_resource_class.py to test_resource_class.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/tests/__init__.py to __init__.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/plugin.py to plugin.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/__init__.py to __init__.cpython-313.pyc
 byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/http.py to http.cpython-313.pyc
-byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/version.py to version.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/common.py to common.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/inventory.py to inventory.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/resource_class.py to resource_class.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/usage.py to usage.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/__init__.py to __init__.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/aggregate.py to aggregate.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/allocation.py to allocation.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/trait.py to trait.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/resource_provider.py to resource_provider.cpython-313.pyc
+byte-compiling /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement/resources/allocation_candidate.py to allocation_candidate.cpython-313.pyc
 running install_egg_info
 removing '/build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement-4.5.0.egg-info' (and everything under it)
 Copying osc_placement.egg-info to /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages/osc_placement-4.5.0.egg-info
 Skipping SOURCES.txt
 running install_scripts
-+ pwd
-+ rm -rf /build/reproducible-path/python-osc-placement-4.5.0/debian/python*/usr/lib/python*/dist-packages/*.pth
-+ pwd
-+ rm -rf /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python*/dist-packages/*.pth
+++ pwd
++ rm -rf '/build/reproducible-path/python-osc-placement-4.5.0/debian/python*/usr/lib/python*/dist-packages/*.pth'
+++ pwd
++ rm -rf '/build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python*/dist-packages/*.pth'
 pkgos-dh_auto_test --no-py2
 + PKGOS_TEST_PARALLEL=yes
 + PKGOS_TEST_SERIAL=no
@@ -1818,47 +1860,50 @@
 + PYTHON3S=disabled
 + TEST_PARALLEL_OPT=--parallel
 + TEST_SERIAL_OPT=
-+ echo WARNING: --no-py2 is deprecated, and always on.
++ for i in $@
++ case "${1}" in
++ echo 'WARNING: --no-py2 is deprecated, and always on.'
 WARNING: --no-py2 is deprecated, and always on.
 + shift
-+ py3versions -vr
-+ PYTHON3S=3.12 3.13
-+ [ yes = no ]
-+ [ no = yes ]
-+ [ 3.12 = disabled ]
-+ echo 3.12
-+ cut -d. -f1
+++ py3versions -vr
++ PYTHON3S='3.12 3.13'
++ '[' yes = no ']'
++ '[' no = yes ']'
++ for pyvers in ${PYTHON3S}
++ '[' 3.12 = disabled ']'
+++ echo 3.12
+++ cut -d. -f1
 + PYMAJOR=3
-+ echo ===> Testing with python (python3)
++ echo '===> Testing with python (python3)'
 ===> Testing with python (python3)
-+ pwd
-+ [ -d /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages ]
-+ [ -z  ]
-+ pwd
-+ echo Implicitly adding PYTHONPATH=/build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages
+++ pwd
++ '[' -d /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages ']'
++ '[' -z '' ']'
+++ pwd
++ echo 'Implicitly adding PYTHONPATH=/build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages'
 Implicitly adding PYTHONPATH=/build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages
-+ pwd
+++ pwd
 + export PYTHONPATH=/build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages
-+ [ -e .stestr.conf ]
-+ [ -x /usr/bin/python3-stestr ]
++ PYTHONPATH=/build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages
++ '[' -e .stestr.conf ']'
++ '[' -x /usr/bin/python3-stestr ']'
 + STESTR=stestr
 + rm -rf .stestr
-+ PYTHON=python3.12 stestr run --parallel --subunit
++ PYTHON=python3.12
++ stestr run --parallel --subunit
 + subunit2pyunit
-osc_placement.tests.unit.test_version.TestVersion.test_check_decorator
-osc_placement.tests.unit.test_version.TestVersion.test_check_decorator ... ok
-osc_placement.tests.unit.test_version.TestVersion.test_check_mixin
-osc_placement.tests.unit.test_version.TestVersion.test_check_mixin ... ok
-osc_placement.tests.unit.test_version.TestVersion.test_compare
-osc_placement.tests.unit.test_version.TestVersion.test_compare ... ok
-osc_placement.tests.unit.test_version.TestVersion.test_compare_with_exc
-osc_placement.tests.unit.test_version.TestVersion.test_compare_with_exc ... ok
-osc_placement.tests.unit.test_version.TestVersion.test_get_version_returns_max_no_gap_when_no_session
-osc_placement.tests.unit.test_version.TestVersion.test_get_version_returns_max_no_gap_when_no_session ... ok
-osc_placement.tests.unit.test_version.TestVersion.test_max_version_consistency
-osc_placement.tests.unit.test_version.TestVersion.test_max_version_consistency ... ok
+osc_placement.tests.unit.test_http.TestSessionClient.test_session_client_version
+osc_placement.tests.unit.test_http.TestSessionClient.test_session_client_version ... ok
+osc_placement.tests.unit.test_http.TestSessionClient.test_unexpected_response
+osc_placement.tests.unit.test_http.TestSessionClient.test_unexpected_response ... ok
+osc_placement.tests.unit.test_http.TestSessionClient.test_wrap_http_exceptions
+osc_placement.tests.unit.test_http.TestSessionClient.test_wrap_http_exceptions ... ok
+osc_placement.tests.unit.test_plugin.TestPlugin.test_build_option_parser
+osc_placement.tests.unit.test_plugin.TestPlugin.test_build_option_parser ... ok
 osc_placement.tests.unit.test_allocation.TestAllocation.test_fail_if_cannot_merge_allocations
 osc_placement.tests.unit.test_allocation.TestAllocation.test_fail_if_cannot_merge_allocations ... ok
+osc_placement.tests.unit.test_plugin.TestPlugin.test_make_client
+osc_placement.tests.unit.test_plugin.TestPlugin.test_make_client ... ok
 osc_placement.tests.unit.test_allocation.TestAllocation.test_fail_if_incorrect_format
 osc_placement.tests.unit.test_allocation.TestAllocation.test_fail_if_incorrect_format ... ok
 osc_placement.tests.unit.test_allocation.TestAllocation.test_merge_allocations
@@ -1869,80 +1914,96 @@
 osc_placement.tests.unit.test_common.TestCommon.test_encode ... ok
 osc_placement.tests.unit.test_common.TestCommon.test_encode_custom_encoding
 osc_placement.tests.unit.test_common.TestCommon.test_encode_custom_encoding ... ok
+osc_placement.tests.unit.test_version.TestVersion.test_check_decorator
+osc_placement.tests.unit.test_version.TestVersion.test_check_decorator ... ok
 osc_placement.tests.unit.test_common.TestCommon.test_encode_non_string
 osc_placement.tests.unit.test_common.TestCommon.test_encode_non_string ... ok
-osc_placement.tests.unit.test_plugin.TestPlugin.test_build_option_parser
-osc_placement.tests.unit.test_plugin.TestPlugin.test_build_option_parser ... ok
+osc_placement.tests.unit.test_version.TestVersion.test_check_mixin
+osc_placement.tests.unit.test_version.TestVersion.test_check_mixin ... ok
+osc_placement.tests.unit.test_version.TestVersion.test_compare
+osc_placement.tests.unit.test_version.TestVersion.test_compare ... ok
 osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters
 osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters ... ok
+osc_placement.tests.unit.test_version.TestVersion.test_compare_with_exc
+osc_placement.tests.unit.test_version.TestVersion.test_compare_with_exc ... ok
 osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters_empty
 osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters_empty ... ok
 osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters_unicode_string
 osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters_unicode_string ... ok
-osc_placement.tests.unit.test_plugin.TestPlugin.test_make_client
-osc_placement.tests.unit.test_plugin.TestPlugin.test_make_client ... ok
-osc_placement.tests.unit.test_http.TestSessionClient.test_session_client_version
-osc_placement.tests.unit.test_http.TestSessionClient.test_session_client_version ... ok
-osc_placement.tests.unit.test_http.TestSessionClient.test_unexpected_response
-osc_placement.tests.unit.test_http.TestSessionClient.test_unexpected_response ... ok
-osc_placement.tests.unit.test_http.TestSessionClient.test_wrap_http_exceptions
-osc_placement.tests.unit.test_http.TestSessionClient.test_wrap_http_exceptions ... ok
+osc_placement.tests.unit.test_version.TestVersion.test_get_version_returns_max_no_gap_when_no_session
+osc_placement.tests.unit.test_version.TestVersion.test_get_version_returns_max_no_gap_when_no_session ... ok
+osc_placement.tests.unit.test_version.TestVersion.test_max_version_consistency
+osc_placement.tests.unit.test_version.TestVersion.test_max_version_consistency ... ok
 
 ----------------------------------------------------------------------
-Ran 21 tests in 2.805s
+Ran 21 tests in 0.895s
 
 OK
 + stestr slowest
-Test id                                                                                        Runtime (s)
----------------------------------------------------------------------------------------------  -----------
-osc_placement.tests.unit.test_version.TestVersion.test_check_decorator                         0.003
-osc_placement.tests.unit.test_plugin.TestPlugin.test_make_client                               0.003
-osc_placement.tests.unit.test_http.TestSessionClient.test_session_client_version               0.003
-osc_placement.tests.unit.test_version.TestVersion.test_check_mixin                             0.002
-osc_placement.tests.unit.test_allocation.TestAllocation.test_fail_if_cannot_merge_allocations  0.002
-osc_placement.tests.unit.test_common.TestCommon.test_encode                                    0.002
-osc_placement.tests.unit.test_version.TestVersion.test_compare                                 0.002
-osc_placement.tests.unit.test_plugin.TestPlugin.test_build_option_parser                       0.002
-osc_placement.tests.unit.test_http.TestSessionClient.test_wrap_http_exceptions                 0.002
-osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters_unicode_string           0.001
+Test id                                                                                                Runtime (s)
+-----------------------------------------------------------------------------------------------------  -----------
+osc_placement.tests.unit.test_plugin.TestPlugin.test_make_client                                       0.002
+osc_placement.tests.unit.test_http.TestSessionClient.test_session_client_version                       0.002
+osc_placement.tests.unit.test_version.TestVersion.test_check_decorator                                 0.002
+osc_placement.tests.unit.test_plugin.TestPlugin.test_build_option_parser                               0.001
+osc_placement.tests.unit.test_version.TestVersion.test_check_mixin                                     0.001
+osc_placement.tests.unit.test_allocation.TestAllocation.test_fail_if_cannot_merge_allocations          0.001
+osc_placement.tests.unit.test_common.TestCommon.test_encode                                            0.001
+osc_placement.tests.unit.test_version.TestVersion.test_compare                                         0.001
+osc_placement.tests.unit.test_version.TestVersion.test_get_version_returns_max_no_gap_when_no_session  0.001
+osc_placement.tests.unit.test_allocation.TestAllocation.test_fail_if_incorrect_format                  0.001
 + rm -rf .stestr
-+ [ 3.13 = disabled ]
-+ echo 3.13
-+ cut -d. -f1
++ for pyvers in ${PYTHON3S}
++ '[' 3.13 = disabled ']'
+++ echo 3.13
+++ cut -d. -f1
 + PYMAJOR=3
-+ echo ===> Testing with python (python3)
++ echo '===> Testing with python (python3)'
 ===> Testing with python (python3)
-+ pwd
-+ [ -d /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages ]
-+ [ -z /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages ]
-+ [ -e .stestr.conf ]
-+ [ -x /usr/bin/python3-stestr ]
+++ pwd
++ '[' -d /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages ']'
++ '[' -z /build/reproducible-path/python-osc-placement-4.5.0/debian/tmp/usr/lib/python3/dist-packages ']'
++ '[' -e .stestr.conf ']'
++ '[' -x /usr/bin/python3-stestr ']'
 + STESTR=stestr
 + rm -rf .stestr
-+ PYTHON=python3.13 stestr run --parallel+  --subunit
-subunit2pyunit
++ PYTHON=python3.13
++ stestr run --parallel --subunit
++ subunit2pyunit
 osc_placement.tests.unit.test_http.TestSessionClient.test_session_client_version
 osc_placement.tests.unit.test_http.TestSessionClient.test_session_client_version ... ok
 osc_placement.tests.unit.test_http.TestSessionClient.test_unexpected_response
 osc_placement.tests.unit.test_http.TestSessionClient.test_unexpected_response ... ok
 osc_placement.tests.unit.test_http.TestSessionClient.test_wrap_http_exceptions
 osc_placement.tests.unit.test_http.TestSessionClient.test_wrap_http_exceptions ... ok
-osc_placement.tests.unit.test_common.TestCommon.test_encode
-osc_placement.tests.unit.test_common.TestCommon.test_encode ... ok
+osc_placement.tests.unit.test_version.TestVersion.test_check_decorator
+osc_placement.tests.unit.test_version.TestVersion.test_check_decorator ... ok
+osc_placement.tests.unit.test_version.TestVersion.test_check_mixin
+osc_placement.tests.unit.test_version.TestVersion.test_check_mixin ... ok
+osc_placement.tests.unit.test_version.TestVersion.test_compare
+osc_placement.tests.unit.test_version.TestVersion.test_compare ... ok
 osc_placement.tests.unit.test_allocation.TestAllocation.test_fail_if_cannot_merge_allocations
 osc_placement.tests.unit.test_allocation.TestAllocation.test_fail_if_cannot_merge_allocations ... ok
-osc_placement.tests.unit.test_common.TestCommon.test_encode_custom_encoding
-osc_placement.tests.unit.test_common.TestCommon.test_encode_custom_encoding ... ok
+osc_placement.tests.unit.test_version.TestVersion.test_compare_with_exc
+osc_placement.tests.unit.test_version.TestVersion.test_compare_with_exc ... ok
+osc_placement.tests.unit.test_version.TestVersion.test_get_version_returns_max_no_gap_when_no_session
+osc_placement.tests.unit.test_version.TestVersion.test_get_version_returns_max_no_gap_when_no_session ... ok
 osc_placement.tests.unit.test_allocation.TestAllocation.test_fail_if_incorrect_format
 osc_placement.tests.unit.test_allocation.TestAllocation.test_fail_if_incorrect_format ... ok
-osc_placement.tests.unit.test_common.TestCommon.test_encode_non_string
-osc_placement.tests.unit.test_common.TestCommon.test_encode_non_string ... ok
+osc_placement.tests.unit.test_version.TestVersion.test_max_version_consistency
+osc_placement.tests.unit.test_version.TestVersion.test_max_version_consistency ... ok
 osc_placement.tests.unit.test_allocation.TestAllocation.test_merge_allocations
 osc_placement.tests.unit.test_allocation.TestAllocation.test_merge_allocations ... ok
-osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters
-osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters ... ok
 osc_placement.tests.unit.test_allocation.TestAllocation.test_parse_allocations
 osc_placement.tests.unit.test_allocation.TestAllocation.test_parse_allocations ... ok
+osc_placement.tests.unit.test_common.TestCommon.test_encode
+osc_placement.tests.unit.test_common.TestCommon.test_encode ... ok
+osc_placement.tests.unit.test_common.TestCommon.test_encode_custom_encoding
+osc_placement.tests.unit.test_common.TestCommon.test_encode_custom_encoding ... ok
+osc_placement.tests.unit.test_common.TestCommon.test_encode_non_string
+osc_placement.tests.unit.test_common.TestCommon.test_encode_non_string ... ok
+osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters
+osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters ... ok
 osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters_empty
 osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters_empty ... ok
 osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters_unicode_string
@@ -1951,36 +2012,24 @@
 osc_placement.tests.unit.test_plugin.TestPlugin.test_build_option_parser ... ok
 osc_placement.tests.unit.test_plugin.TestPlugin.test_make_client
 osc_placement.tests.unit.test_plugin.TestPlugin.test_make_client ... ok
-osc_placement.tests.unit.test_version.TestVersion.test_check_decorator
-osc_placement.tests.unit.test_version.TestVersion.test_check_decorator ... ok
-osc_placement.tests.unit.test_version.TestVersion.test_check_mixin
-osc_placement.tests.unit.test_version.TestVersion.test_check_mixin ... ok
-osc_placement.tests.unit.test_version.TestVersion.test_compare
-osc_placement.tests.unit.test_version.TestVersion.test_compare ... ok
-osc_placement.tests.unit.test_version.TestVersion.test_compare_with_exc
-osc_placement.tests.unit.test_version.TestVersion.test_compare_with_exc ... ok
-osc_placement.tests.unit.test_version.TestVersion.test_get_version_returns_max_no_gap_when_no_session
-osc_placement.tests.unit.test_version.TestVersion.test_get_version_returns_max_no_gap_when_no_session ... ok
-osc_placement.tests.unit.test_version.TestVersion.test_max_version_consistency
-osc_placement.tests.unit.test_version.TestVersion.test_max_version_consistency ... ok
 
 ----------------------------------------------------------------------
-Ran 21 tests in 2.909s
+Ran 21 tests in 1.272s
 
 OK
 + stestr slowest
 Test id                                                                                                Runtime (s)
 -----------------------------------------------------------------------------------------------------  -----------
-osc_placement.tests.unit.test_http.TestSessionClient.test_session_client_version                       0.005
-osc_placement.tests.unit.test_version.TestVersion.test_get_version_returns_max_no_gap_when_no_session  0.004
-osc_placement.tests.unit.test_common.TestCommon.test_encode                                            0.003
-osc_placement.tests.unit.test_plugin.TestPlugin.test_make_client                                       0.003
-osc_placement.tests.unit.test_version.TestVersion.test_check_decorator                                 0.003
-osc_placement.tests.unit.test_http.TestSessionClient.test_unexpected_response                          0.003
-osc_placement.tests.unit.test_plugin.TestPlugin.test_build_option_parser                               0.003
-osc_placement.tests.unit.test_version.TestVersion.test_check_mixin                                     0.002
-osc_placement.tests.unit.test_allocation.TestAllocation.test_fail_if_incorrect_format                  0.002
-osc_placement.tests.unit.test_version.TestVersion.test_compare                                         0.002
+osc_placement.tests.unit.test_plugin.TestPlugin.test_make_client                                       0.002
+osc_placement.tests.unit.test_version.TestVersion.test_check_decorator                                 0.002
+osc_placement.tests.unit.test_http.TestSessionClient.test_session_client_version                       0.001
+osc_placement.tests.unit.test_plugin.TestPlugin.test_build_option_parser                               0.001
+osc_placement.tests.unit.test_allocation.TestAllocation.test_fail_if_cannot_merge_allocations          0.001
+osc_placement.tests.unit.test_common.TestCommon.test_encode                                            0.001
+osc_placement.tests.unit.test_version.TestVersion.test_compare                                         0.001
+osc_placement.tests.unit.test_version.TestVersion.test_get_version_returns_max_no_gap_when_no_session  0.001
+osc_placement.tests.unit.test_version.TestVersion.test_check_mixin                                     0.001
+osc_placement.tests.unit.test_common.TestCommon.test_url_with_filters                                  0.001
 + rm -rf .stestr
 make[1]: Leaving directory '/build/reproducible-path/python-osc-placement-4.5.0'
    dh_install -O--buildsystem=pybuild
@@ -2014,9 +2063,9 @@
 preparing documents... done
 copying assets... 
 copying static files... 
+Writing evaluated template result to /build/reproducible-path/python-osc-placement-4.5.0/debian/python-osc-placement-doc/usr/share/doc/python-osc-placement-doc/html/_static/documentation_options.js
 Writing evaluated template result to /build/reproducible-path/python-osc-placement-4.5.0/debian/python-osc-placement-doc/usr/share/doc/python-osc-placement-doc/html/_static/language_data.js
 Writing evaluated template result to /build/reproducible-path/python-osc-placement-4.5.0/debian/python-osc-placement-doc/usr/share/doc/python-osc-placement-doc/html/_static/basic.css
-Writing evaluated template result to /build/reproducible-path/python-osc-placement-4.5.0/debian/python-osc-placement-doc/usr/share/doc/python-osc-placement-doc/html/_static/documentation_options.js
 copying static files: done
 copying extra files... 
 copying extra files: done
@@ -2064,10 +2113,10 @@
 
 The HTML pages are in debian/python-osc-placement-doc/usr/share/doc/python-osc-placement-doc/html.
 dh_sphinxdoc -O--buildsystem=pybuild
+dh_sphinxdoc: warning: ignoring unknown JavaScript code: debian/python-osc-placement-doc/usr/share/doc/python-osc-placement-doc/html/_static/js/navigation.js
 dh_sphinxdoc: warning: ignoring unknown JavaScript code: debian/python-osc-placement-doc/usr/share/doc/python-osc-placement-doc/html/_static/js/bootstrap.min.js
 dh_sphinxdoc: warning: ignoring unknown JavaScript code: debian/python-osc-placement-doc/usr/share/doc/python-osc-placement-doc/html/_static/js/docs.js
 dh_sphinxdoc: warning: ignoring unknown JavaScript code: debian/python-osc-placement-doc/usr/share/doc/python-osc-placement-doc/html/_static/js/jquery-3.2.1.min.js
-dh_sphinxdoc: warning: ignoring unknown JavaScript code: debian/python-osc-placement-doc/usr/share/doc/python-osc-placement-doc/html/_static/js/navigation.js
 make[1]: Leaving directory '/build/reproducible-path/python-osc-placement-4.5.0'
    debian/rules override_dh_installchangelogs
 make[1]: Entering directory '/build/reproducible-path/python-osc-placement-4.5.0'
@@ -2092,14 +2141,14 @@
 	cat /usr/share/openstack-pkg-tools/init-script-template >>$MYINIT.init ; \
 	pkgos-gen-systemd-unit $i ; \
 done
-+ ls -1 debian/*.init.in
+++ ls -1 'debian/*.init.in'
 ls: cannot access 'debian/*.init.in': No such file or directory
 # If there's a service.in file, use that one instead of the generated one
 set -e ; set -x ; for i in `ls -1 debian/*.service.in`; do \
 	MYPKG=`echo $i | sed s/.service.in//` ; \
 	cp $MYPKG.service.in $MYPKG.service ; \
 done
-+ ls -1 debian/*.service.in
+++ ls -1 'debian/*.service.in'
 ls: cannot access 'debian/*.service.in': No such file or directory
 # Generate the systemd unit if there's no already existing .service.in
 set -e ; set -x ; for i in `ls debian/*.init.in` ; do \
@@ -2108,7 +2157,7 @@
 		pkgos-gen-systemd-unit $i ; \
 	fi \
 done
-+ ls debian/*.init.in
+++ ls 'debian/*.init.in'
 ls: cannot access 'debian/*.init.in': No such file or directory
 dh_installinit --error-handler=true
 make[1]: Leaving directory '/build/reproducible-path/python-osc-placement-4.5.0'
@@ -2143,12 +2192,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/3629279/tmp/hooks/B01_cleanup starting
+I: user script /srv/workspace/pbuilder/3629279/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/2793814 and its subdirectories
-I: Current time: Sat Feb 15 20:39:25 -12 2025
-I: pbuilder-time-stamp: 1739695165
+I: removing directory /srv/workspace/pbuilder/3629279 and its subdirectories
+I: Current time: Sun Mar 22 05:06:42 +14 2026
+I: pbuilder-time-stamp: 1774105602