Diff of the two buildlogs: -- --- b1/build.log 2024-12-02 02:19:04.720950160 +0000 +++ b2/build.log 2024-12-02 02:23:30.753002887 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Sat Jan 3 20:41:00 -12 2026 -I: pbuilder-time-stamp: 1767516060 +I: Current time: Mon Dec 2 16:19:07 +14 2024 +I: pbuilder-time-stamp: 1733105947 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/unstable-reproducible-base.tgz] I: copying local configuration @@ -26,54 +26,86 @@ dpkg-source: info: unpacking asgi-lifespan_2.1.0-3.debian.tar.xz I: Not using root during the build. I: Installing the build-deps -I: user script /srv/workspace/pbuilder/54318/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/6436/tmp/hooks/D01_modify_environment starting +debug: Running on ionos2-i386. +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 2 02:19 /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/6436/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/6436/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='i386' - DEBIAN_FRONTEND='noninteractive' - DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=22 ' - DISTRIBUTION='unstable' - HOME='/root' - HOST_ARCH='i386' + 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]="i686-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=i386 + DEBIAN_FRONTEND=noninteractive + DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=10 ' + DIRSTACK=() + DISTRIBUTION=unstable + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=i686 + HOST_ARCH=i386 IFS=' ' - INVOCATION_ID='5ac4aeed878c41d4b71dc841326e3b7b' - LANG='C' - LANGUAGE='en_US:en' - LC_ALL='C' - LD_LIBRARY_PATH='/usr/lib/libeatmydata' - LD_PRELOAD='libeatmydata.so' - 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='54318' - PS1='# ' - PS2='> ' + INVOCATION_ID=c668be4d387d4a6ca528416163bdff3e + LANG=C + LANGUAGE=de_CH:de + LC_ALL=C + LD_LIBRARY_PATH=/usr/lib/libeatmydata + LD_PRELOAD=libeatmydata.so + MACHTYPE=i686-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=6436 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.WJpPipu6/pbuilderrc_6ejb --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.WJpPipu6/b1 --logfile b1/build.log asgi-lifespan_2.1.0-3.dsc' - SUDO_GID='112' - SUDO_UID='107' - SUDO_USER='jenkins' - TERM='unknown' - TZ='/usr/share/zoneinfo/Etc/GMT+12' - USER='root' - _='/usr/bin/systemd-run' - http_proxy='http://213.165.73.152: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.WJpPipu6/pbuilderrc_xnsa --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.WJpPipu6/b2 --logfile b2/build.log asgi-lifespan_2.1.0-3.dsc' + SUDO_GID=112 + SUDO_UID=107 + SUDO_USER=jenkins + TERM=unknown + TZ=/usr/share/zoneinfo/Etc/GMT-14 + UID=0 + USER=root + _='I: set' + http_proxy=http://46.16.76.132:3128 I: uname -a - Linux ionos16-i386 6.1.0-28-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.119-1 (2024-11-22) x86_64 GNU/Linux + Linux i-capture-the-hostname 6.1.0-28-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.119-1 (2024-11-22) 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/54318/tmp/hooks/D02_print_environment finished + lrwxrwxrwx 1 root root 7 Nov 22 14:40 /bin -> usr/bin +I: user script /srv/workspace/pbuilder/6436/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy @@ -265,7 +297,7 @@ Get: 126 http://deb.debian.org/debian unstable/main i386 python3-twisted all 24.10.0-2 [2048 kB] Get: 127 http://deb.debian.org/debian unstable/main i386 python3-pytest-twisted all 1.14.1-3 [13.9 kB] Get: 128 http://deb.debian.org/debian unstable/main i386 python3-starlette all 0.41.3-2 [51.2 kB] -Fetched 43.6 MB in 2s (26.7 MB/s) +Fetched 43.6 MB in 1s (32.6 MB/s) debconf: delaying package configuration, since apt-utils is not installed Selecting previously unselected package libjs-jquery. (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 ... 19956 files and directories currently installed.) @@ -684,8 +716,8 @@ Setting up tzdata (2024b-3) ... Current default time zone: 'Etc/UTC' -Local time is now: Sun Jan 4 08:41:22 UTC 2026. -Universal Time is now: Sun Jan 4 08:41:22 UTC 2026. +Local time is now: Mon Dec 2 02:20:42 UTC 2024. +Universal Time is now: Mon Dec 2 02:20:42 UTC 2024. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up libpython3.13-minimal:i386 (3.13.0-2) ... @@ -813,7 +845,11 @@ Building tag database... -> Finished parsing the build-deps I: Building the package -I: Running cd /build/reproducible-path/asgi-lifespan-2.1.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 > ../asgi-lifespan_2.1.0-3_source.changes +I: user script /srv/workspace/pbuilder/6436/tmp/hooks/A99_set_merged_usr starting +Not re-configuring usrmerge for unstable +I: user script /srv/workspace/pbuilder/6436/tmp/hooks/A99_set_merged_usr finished +hostname: Name or service not known +I: Running cd /build/reproducible-path/asgi-lifespan-2.1.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 > ../asgi-lifespan_2.1.0-3_source.changes dpkg-buildpackage: info: source package asgi-lifespan dpkg-buildpackage: info: source version 2.1.0-3 dpkg-buildpackage: info: source distribution unstable @@ -847,15 +883,15 @@ running build_py creating build/lib/asgi_lifespan copying src/asgi_lifespan/_compat.py -> build/lib/asgi_lifespan +copying src/asgi_lifespan/_exceptions.py -> build/lib/asgi_lifespan copying src/asgi_lifespan/_types.py -> build/lib/asgi_lifespan -copying src/asgi_lifespan/_manager.py -> build/lib/asgi_lifespan copying src/asgi_lifespan/__init__.py -> build/lib/asgi_lifespan -copying src/asgi_lifespan/_exceptions.py -> build/lib/asgi_lifespan +copying src/asgi_lifespan/_manager.py -> build/lib/asgi_lifespan creating build/lib/asgi_lifespan/_concurrency -copying src/asgi_lifespan/_concurrency/__init__.py -> build/lib/asgi_lifespan/_concurrency +copying src/asgi_lifespan/_concurrency/base.py -> build/lib/asgi_lifespan/_concurrency copying src/asgi_lifespan/_concurrency/asyncio.py -> build/lib/asgi_lifespan/_concurrency copying src/asgi_lifespan/_concurrency/trio.py -> build/lib/asgi_lifespan/_concurrency -copying src/asgi_lifespan/_concurrency/base.py -> build/lib/asgi_lifespan/_concurrency +copying src/asgi_lifespan/_concurrency/__init__.py -> build/lib/asgi_lifespan/_concurrency running egg_info creating src/asgi_lifespan.egg-info writing src/asgi_lifespan.egg-info/PKG-INFO @@ -873,22 +909,22 @@ running install_lib creating build/bdist.linux-i686/wheel creating build/bdist.linux-i686/wheel/asgi_lifespan -copying build/lib/asgi_lifespan/_compat.py -> build/bdist.linux-i686/wheel/./asgi_lifespan -copying build/lib/asgi_lifespan/_types.py -> build/bdist.linux-i686/wheel/./asgi_lifespan -copying build/lib/asgi_lifespan/_manager.py -> build/bdist.linux-i686/wheel/./asgi_lifespan -copying build/lib/asgi_lifespan/py.typed -> build/bdist.linux-i686/wheel/./asgi_lifespan creating build/bdist.linux-i686/wheel/asgi_lifespan/_concurrency -copying build/lib/asgi_lifespan/_concurrency/__init__.py -> build/bdist.linux-i686/wheel/./asgi_lifespan/_concurrency +copying build/lib/asgi_lifespan/_concurrency/base.py -> build/bdist.linux-i686/wheel/./asgi_lifespan/_concurrency copying build/lib/asgi_lifespan/_concurrency/asyncio.py -> build/bdist.linux-i686/wheel/./asgi_lifespan/_concurrency copying build/lib/asgi_lifespan/_concurrency/trio.py -> build/bdist.linux-i686/wheel/./asgi_lifespan/_concurrency -copying build/lib/asgi_lifespan/_concurrency/base.py -> build/bdist.linux-i686/wheel/./asgi_lifespan/_concurrency -copying build/lib/asgi_lifespan/__init__.py -> build/bdist.linux-i686/wheel/./asgi_lifespan +copying build/lib/asgi_lifespan/_concurrency/__init__.py -> build/bdist.linux-i686/wheel/./asgi_lifespan/_concurrency +copying build/lib/asgi_lifespan/py.typed -> build/bdist.linux-i686/wheel/./asgi_lifespan +copying build/lib/asgi_lifespan/_compat.py -> build/bdist.linux-i686/wheel/./asgi_lifespan copying build/lib/asgi_lifespan/_exceptions.py -> build/bdist.linux-i686/wheel/./asgi_lifespan +copying build/lib/asgi_lifespan/_types.py -> build/bdist.linux-i686/wheel/./asgi_lifespan +copying build/lib/asgi_lifespan/__init__.py -> build/bdist.linux-i686/wheel/./asgi_lifespan +copying build/lib/asgi_lifespan/_manager.py -> build/bdist.linux-i686/wheel/./asgi_lifespan running install_egg_info Copying src/asgi_lifespan.egg-info to build/bdist.linux-i686/wheel/./asgi_lifespan-2.1.0.egg-info running install_scripts creating build/bdist.linux-i686/wheel/asgi_lifespan-2.1.0.dist-info/WHEEL -creating '/build/reproducible-path/asgi-lifespan-2.1.0/.pybuild/cpython3_3.13_asgi-lifespan/.tmp-74yinckv/asgi_lifespan-2.1.0-py3-none-any.whl' and adding 'build/bdist.linux-i686/wheel' to it +creating '/build/reproducible-path/asgi-lifespan-2.1.0/.pybuild/cpython3_3.13_asgi-lifespan/.tmp-w5941h5_/asgi_lifespan-2.1.0-py3-none-any.whl' and adding 'build/bdist.linux-i686/wheel' to it adding 'asgi_lifespan/__init__.py' adding 'asgi_lifespan/_compat.py' adding 'asgi_lifespan/_exceptions.py' @@ -931,22 +967,22 @@ running install_lib creating build/bdist.linux-i686/wheel creating build/bdist.linux-i686/wheel/asgi_lifespan -copying build/lib/asgi_lifespan/_compat.py -> build/bdist.linux-i686/wheel/./asgi_lifespan -copying build/lib/asgi_lifespan/_types.py -> build/bdist.linux-i686/wheel/./asgi_lifespan -copying build/lib/asgi_lifespan/_manager.py -> build/bdist.linux-i686/wheel/./asgi_lifespan -copying build/lib/asgi_lifespan/py.typed -> build/bdist.linux-i686/wheel/./asgi_lifespan creating build/bdist.linux-i686/wheel/asgi_lifespan/_concurrency -copying build/lib/asgi_lifespan/_concurrency/__init__.py -> build/bdist.linux-i686/wheel/./asgi_lifespan/_concurrency +copying build/lib/asgi_lifespan/_concurrency/base.py -> build/bdist.linux-i686/wheel/./asgi_lifespan/_concurrency copying build/lib/asgi_lifespan/_concurrency/asyncio.py -> build/bdist.linux-i686/wheel/./asgi_lifespan/_concurrency copying build/lib/asgi_lifespan/_concurrency/trio.py -> build/bdist.linux-i686/wheel/./asgi_lifespan/_concurrency -copying build/lib/asgi_lifespan/_concurrency/base.py -> build/bdist.linux-i686/wheel/./asgi_lifespan/_concurrency -copying build/lib/asgi_lifespan/__init__.py -> build/bdist.linux-i686/wheel/./asgi_lifespan +copying build/lib/asgi_lifespan/_concurrency/__init__.py -> build/bdist.linux-i686/wheel/./asgi_lifespan/_concurrency +copying build/lib/asgi_lifespan/py.typed -> build/bdist.linux-i686/wheel/./asgi_lifespan +copying build/lib/asgi_lifespan/_compat.py -> build/bdist.linux-i686/wheel/./asgi_lifespan copying build/lib/asgi_lifespan/_exceptions.py -> build/bdist.linux-i686/wheel/./asgi_lifespan +copying build/lib/asgi_lifespan/_types.py -> build/bdist.linux-i686/wheel/./asgi_lifespan +copying build/lib/asgi_lifespan/__init__.py -> build/bdist.linux-i686/wheel/./asgi_lifespan +copying build/lib/asgi_lifespan/_manager.py -> build/bdist.linux-i686/wheel/./asgi_lifespan running install_egg_info Copying src/asgi_lifespan.egg-info to build/bdist.linux-i686/wheel/./asgi_lifespan-2.1.0.egg-info running install_scripts creating build/bdist.linux-i686/wheel/asgi_lifespan-2.1.0.dist-info/WHEEL -creating '/build/reproducible-path/asgi-lifespan-2.1.0/.pybuild/cpython3_3.12_asgi-lifespan/.tmp-pdmqfbs3/asgi_lifespan-2.1.0-py3-none-any.whl' and adding 'build/bdist.linux-i686/wheel' to it +creating '/build/reproducible-path/asgi-lifespan-2.1.0/.pybuild/cpython3_3.12_asgi-lifespan/.tmp-v3us_rkg/asgi_lifespan-2.1.0-py3-none-any.whl' and adding 'build/bdist.linux-i686/wheel' to it adding 'asgi_lifespan/__init__.py' adding 'asgi_lifespan/_compat.py' adding 'asgi_lifespan/_exceptions.py' @@ -975,7 +1011,7 @@ platform linux -- Python 3.13.0, pytest-8.3.3, pluggy-1.5.0 rootdir: /dev configfile: null -plugins: twisted-1.14.1, trio-0.8.0, cov-5.0.0, anyio-4.6.2, asyncio-0.24.0a1, tornasync-0.6.0.post2, typeguard-4.4.1 +plugins: typeguard-4.4.1, trio-0.8.0, anyio-4.6.2, cov-5.0.0, asyncio-0.24.0a1, tornasync-0.6.0.post2, twisted-1.14.1 asyncio: mode=Mode.STRICT, default_loop_scope=None collected 32 items / 17 deselected / 15 selected @@ -992,7 +1028,7 @@ warnings.warn( -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html -=========== 14 passed, 17 deselected, 1 xfailed, 6 warnings in 0.31s =========== +=========== 14 passed, 17 deselected, 1 xfailed, 6 warnings in 1.05s =========== I: pybuild base:311: cd /build/reproducible-path/asgi-lifespan-2.1.0/.pybuild/cpython3_3.12_asgi-lifespan/build; python3.12 -m pytest -c /dev/null --asyncio-mode=strict -p no:cacheprovider -m "not trio" -k "not test_lifespan_state_async_cm" /usr/lib/python3/dist-packages/pytest_asyncio/plugin.py:208: PytestDeprecationWarning: The configuration option "asyncio_default_fixture_loop_scope" is unset. The event loop scope for asynchronous fixtures will default to the fixture caching scope. Future versions of pytest-asyncio will default the loop scope for asynchronous fixtures to function scope. Set the default fixture loop scope explicitly in order to avoid unexpected behavior in the future. Valid fixture loop scopes are: "function", "class", "module", "package", "session" @@ -1002,7 +1038,7 @@ platform linux -- Python 3.12.7, pytest-8.3.3, pluggy-1.5.0 rootdir: /dev configfile: null -plugins: twisted-1.14.1, trio-0.8.0, cov-5.0.0, anyio-4.6.2, asyncio-0.24.0a1, tornasync-0.6.0.post2, typeguard-4.4.1 +plugins: typeguard-4.4.1, trio-0.8.0, anyio-4.6.2, cov-5.0.0, asyncio-0.24.0a1, tornasync-0.6.0.post2, twisted-1.14.1 asyncio: mode=Mode.STRICT, default_loop_scope=None collected 32 items / 17 deselected / 15 selected @@ -1019,7 +1055,7 @@ warnings.warn( -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html -=========== 14 passed, 17 deselected, 1 xfailed, 6 warnings in 0.32s =========== +=========== 14 passed, 17 deselected, 1 xfailed, 6 warnings in 1.38s =========== create-stamp debian/debhelper-build-stamp dh_testroot -O--buildsystem=pybuild dh_prep -O--buildsystem=pybuild @@ -1048,12 +1084,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/6436/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/6436/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/54318 and its subdirectories -I: Current time: Sat Jan 3 20:42:02 -12 2026 -I: pbuilder-time-stamp: 1767516122 +I: removing directory /srv/workspace/pbuilder/6436 and its subdirectories +I: Current time: Mon Dec 2 16:23:29 +14 2024 +I: pbuilder-time-stamp: 1733106209