Diff of the two buildlogs: -- --- b1/build.log 2023-05-23 09:43:03.567565076 +0000 +++ b2/build.log 2023-05-23 09:45:20.105602409 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Mon May 22 21:34:59 -12 2023 -I: pbuilder-time-stamp: 1684834499 +I: Current time: Tue May 23 23:43:19 +14 2023 +I: pbuilder-time-stamp: 1684834999 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/bookworm-reproducible-base.tgz] I: copying local configuration @@ -16,7 +16,7 @@ I: copying [./ruby-omniauth_2.1.1.orig.tar.gz] I: copying [./ruby-omniauth_2.1.1-1.debian.tar.xz] I: Extracting source -gpgv: Signature made Sat Jan 21 19:35:17 2023 -12 +gpgv: Signature made Sun Jan 22 21:35:17 2023 +14 gpgv: using EDDSA key A095B66EE09024BEE6A2F0722A27904BD7243EDA gpgv: Can't check signature: No public key dpkg-source: warning: cannot verify inline signature for ./ruby-omniauth_2.1.1-1.dsc: no acceptable signature found @@ -29,135 +29,167 @@ dpkg-source: info: applying 0003-spec-helper.rb-drop-rack-freeze-usage.patch I: Not using root during the build. I: Installing the build-deps -I: user script /srv/workspace/pbuilder/13758/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/32694/tmp/hooks/D01_modify_environment starting +debug: Running on virt64c. +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 May 23 23:43 /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/32694/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/32694/tmp/hooks/D02_print_environment starting I: set - BUILDDIR='/build' - BUILDUSERGECOS='first user,first room,first work-phone,first home-phone,first other' - BUILDUSERNAME='pbuilder1' - BUILD_ARCH='armhf' - DEBIAN_FRONTEND='noninteractive' - DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=3 ' - DISTRIBUTION='bookworm' - HOME='/root' - HOST_ARCH='armhf' + 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]="15" [3]="1" [4]="release" [5]="arm-unknown-linux-gnueabihf") + BASH_VERSION='5.2.15(1)-release' + BUILDDIR=/build + BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' + BUILDUSERNAME=pbuilder2 + BUILD_ARCH=armhf + DEBIAN_FRONTEND=noninteractive + DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=4 ' + DIRSTACK=() + DISTRIBUTION=bookworm + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=arm + HOST_ARCH=armhf IFS=' ' - INVOCATION_ID='e45fa1cd28c54670a75aae37e190a56a' - 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='13758' - PS1='# ' - PS2='> ' + INVOCATION_ID=521c0d95857d4bb1adf9de13a5c5ccc7 + LANG=C + LANGUAGE=it_CH:it + LC_ALL=C + MACHTYPE=arm-unknown-linux-gnueabihf + MAIL=/var/mail/root + OPTERR=1 + OPTIND=1 + OSTYPE=linux-gnueabihf + 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=32694 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.wiMW3Qaj/pbuilderrc_FJXN --distribution bookworm --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/bookworm-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.wiMW3Qaj/b1 --logfile b1/build.log ruby-omniauth_2.1.1-1.dsc' - SUDO_GID='116' - SUDO_UID='112' - SUDO_USER='jenkins' - TERM='unknown' - TZ='/usr/share/zoneinfo/Etc/GMT+12' - USER='root' - _='/usr/bin/systemd-run' - http_proxy='http://10.0.0.15:3142/' + 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.wiMW3Qaj/pbuilderrc_eWa1 --distribution bookworm --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/bookworm-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.wiMW3Qaj/b2 --logfile b2/build.log --extrapackages usrmerge ruby-omniauth_2.1.1-1.dsc' + SUDO_GID=113 + SUDO_UID=107 + SUDO_USER=jenkins + TERM=unknown + TZ=/usr/share/zoneinfo/Etc/GMT-14 + UID=0 + USER=root + _='I: set' + http_proxy=http://10.0.0.15:3142/ I: uname -a - Linux cbxi4b 5.10.0-23-armmp #1 SMP Debian 5.10.179-1 (2023-05-12) armv7l GNU/Linux + Linux i-capture-the-hostname 5.10.0-23-arm64 #1 SMP Debian 5.10.179-1 (2023-05-12) aarch64 GNU/Linux I: ls -l /bin total 5072 - -rwxr-xr-x 1 root root 838488 Apr 23 09:24 bash - -rwxr-xr-x 3 root root 67144 Sep 18 2022 bunzip2 - -rwxr-xr-x 3 root root 67144 Sep 18 2022 bzcat - lrwxrwxrwx 1 root root 6 Sep 18 2022 bzcmp -> bzdiff - -rwxr-xr-x 1 root root 2225 Sep 18 2022 bzdiff - lrwxrwxrwx 1 root root 6 Sep 18 2022 bzegrep -> bzgrep - -rwxr-xr-x 1 root root 4893 Nov 27 2021 bzexe - lrwxrwxrwx 1 root root 6 Sep 18 2022 bzfgrep -> bzgrep - -rwxr-xr-x 1 root root 3775 Sep 18 2022 bzgrep - -rwxr-xr-x 3 root root 67144 Sep 18 2022 bzip2 - -rwxr-xr-x 1 root root 67112 Sep 18 2022 bzip2recover - lrwxrwxrwx 1 root root 6 Sep 18 2022 bzless -> bzmore - -rwxr-xr-x 1 root root 1297 Sep 18 2022 bzmore - -rwxr-xr-x 1 root root 67632 Sep 20 2022 cat - -rwxr-xr-x 1 root root 67676 Sep 20 2022 chgrp - -rwxr-xr-x 1 root root 67644 Sep 20 2022 chmod - -rwxr-xr-x 1 root root 67684 Sep 20 2022 chown - -rwxr-xr-x 1 root root 133532 Sep 20 2022 cp - -rwxr-xr-x 1 root root 132868 Jan 5 01:20 dash - -rwxr-xr-x 1 root root 133220 Sep 20 2022 date - -rwxr-xr-x 1 root root 67732 Sep 20 2022 dd - -rwxr-xr-x 1 root root 68104 Sep 20 2022 df - -rwxr-xr-x 1 root root 133632 Sep 20 2022 dir - -rwxr-xr-x 1 root root 59128 Mar 22 21:02 dmesg - lrwxrwxrwx 1 root root 8 Dec 19 01:33 dnsdomainname -> hostname - lrwxrwxrwx 1 root root 8 Dec 19 01:33 domainname -> hostname - -rwxr-xr-x 1 root root 67560 Sep 20 2022 echo - -rwxr-xr-x 1 root root 41 Jan 24 02:43 egrep - -rwxr-xr-x 1 root root 67548 Sep 20 2022 false - -rwxr-xr-x 1 root root 41 Jan 24 02:43 fgrep - -rwxr-xr-x 1 root root 55748 Mar 22 21:02 findmnt - -rwsr-xr-x 1 root root 26208 Mar 22 20:15 fusermount - -rwxr-xr-x 1 root root 128608 Jan 24 02:43 grep - -rwxr-xr-x 2 root root 2346 Apr 9 2022 gunzip - -rwxr-xr-x 1 root root 6447 Apr 9 2022 gzexe - -rwxr-xr-x 1 root root 64220 Apr 9 2022 gzip - -rwxr-xr-x 1 root root 67032 Dec 19 01:33 hostname - -rwxr-xr-x 1 root root 67720 Sep 20 2022 ln - -rwxr-xr-x 1 root root 35132 Mar 22 21:51 login - -rwxr-xr-x 1 root root 133632 Sep 20 2022 ls - -rwxr-xr-x 1 root root 136808 Mar 22 21:02 lsblk - -rwxr-xr-x 1 root root 67800 Sep 20 2022 mkdir - -rwxr-xr-x 1 root root 67764 Sep 20 2022 mknod - -rwxr-xr-x 1 root root 67596 Sep 20 2022 mktemp - -rwxr-xr-x 1 root root 38504 Mar 22 21:02 more - -rwsr-xr-x 1 root root 38496 Mar 22 21:02 mount - -rwxr-xr-x 1 root root 9824 Mar 22 21:02 mountpoint - -rwxr-xr-x 1 root root 133532 Sep 20 2022 mv - lrwxrwxrwx 1 root root 8 Dec 19 01:33 nisdomainname -> hostname - lrwxrwxrwx 1 root root 14 Apr 2 18:25 pidof -> /sbin/killall5 - -rwxr-xr-x 1 root root 67608 Sep 20 2022 pwd - lrwxrwxrwx 1 root root 4 Apr 23 09:24 rbash -> bash - -rwxr-xr-x 1 root root 67600 Sep 20 2022 readlink - -rwxr-xr-x 1 root root 67672 Sep 20 2022 rm - -rwxr-xr-x 1 root root 67600 Sep 20 2022 rmdir - -rwxr-xr-x 1 root root 67400 Nov 2 2022 run-parts - -rwxr-xr-x 1 root root 133372 Jan 5 07:55 sed - lrwxrwxrwx 1 root root 4 Jan 5 01:20 sh -> dash - -rwxr-xr-x 1 root root 67584 Sep 20 2022 sleep - -rwxr-xr-x 1 root root 67644 Sep 20 2022 stty - -rwsr-xr-x 1 root root 50800 Mar 22 21:02 su - -rwxr-xr-x 1 root root 67584 Sep 20 2022 sync - -rwxr-xr-x 1 root root 336764 Apr 6 02:25 tar - -rwxr-xr-x 1 root root 67144 Nov 2 2022 tempfile - -rwxr-xr-x 1 root root 133224 Sep 20 2022 touch - -rwxr-xr-x 1 root root 67548 Sep 20 2022 true - -rwxr-xr-x 1 root root 9768 Mar 22 20:15 ulockmgr_server - -rwsr-xr-x 1 root root 22108 Mar 22 21:02 umount - -rwxr-xr-x 1 root root 67572 Sep 20 2022 uname - -rwxr-xr-x 2 root root 2346 Apr 9 2022 uncompress - -rwxr-xr-x 1 root root 133632 Sep 20 2022 vdir - -rwxr-xr-x 1 root root 42608 Mar 22 21:02 wdctl - lrwxrwxrwx 1 root root 8 Dec 19 01:33 ypdomainname -> hostname - -rwxr-xr-x 1 root root 1984 Apr 9 2022 zcat - -rwxr-xr-x 1 root root 1678 Apr 9 2022 zcmp - -rwxr-xr-x 1 root root 6460 Apr 9 2022 zdiff - -rwxr-xr-x 1 root root 29 Apr 9 2022 zegrep - -rwxr-xr-x 1 root root 29 Apr 9 2022 zfgrep - -rwxr-xr-x 1 root root 2081 Apr 9 2022 zforce - -rwxr-xr-x 1 root root 8103 Apr 9 2022 zgrep - -rwxr-xr-x 1 root root 2206 Apr 9 2022 zless - -rwxr-xr-x 1 root root 1842 Apr 9 2022 zmore - -rwxr-xr-x 1 root root 4577 Apr 9 2022 znew -I: user script /srv/workspace/pbuilder/13758/tmp/hooks/D02_print_environment finished + -rwxr-xr-x 1 root root 838488 Apr 24 11:24 bash + -rwxr-xr-x 3 root root 67144 Sep 19 2022 bunzip2 + -rwxr-xr-x 3 root root 67144 Sep 19 2022 bzcat + lrwxrwxrwx 1 root root 6 Sep 19 2022 bzcmp -> bzdiff + -rwxr-xr-x 1 root root 2225 Sep 19 2022 bzdiff + lrwxrwxrwx 1 root root 6 Sep 19 2022 bzegrep -> bzgrep + -rwxr-xr-x 1 root root 4893 Nov 28 2021 bzexe + lrwxrwxrwx 1 root root 6 Sep 19 2022 bzfgrep -> bzgrep + -rwxr-xr-x 1 root root 3775 Sep 19 2022 bzgrep + -rwxr-xr-x 3 root root 67144 Sep 19 2022 bzip2 + -rwxr-xr-x 1 root root 67112 Sep 19 2022 bzip2recover + lrwxrwxrwx 1 root root 6 Sep 19 2022 bzless -> bzmore + -rwxr-xr-x 1 root root 1297 Sep 19 2022 bzmore + -rwxr-xr-x 1 root root 67632 Sep 21 2022 cat + -rwxr-xr-x 1 root root 67676 Sep 21 2022 chgrp + -rwxr-xr-x 1 root root 67644 Sep 21 2022 chmod + -rwxr-xr-x 1 root root 67684 Sep 21 2022 chown + -rwxr-xr-x 1 root root 133532 Sep 21 2022 cp + -rwxr-xr-x 1 root root 132868 Jan 6 03:20 dash + -rwxr-xr-x 1 root root 133220 Sep 21 2022 date + -rwxr-xr-x 1 root root 67732 Sep 21 2022 dd + -rwxr-xr-x 1 root root 68104 Sep 21 2022 df + -rwxr-xr-x 1 root root 133632 Sep 21 2022 dir + -rwxr-xr-x 1 root root 59128 Mar 23 23:02 dmesg + lrwxrwxrwx 1 root root 8 Dec 20 03:33 dnsdomainname -> hostname + lrwxrwxrwx 1 root root 8 Dec 20 03:33 domainname -> hostname + -rwxr-xr-x 1 root root 67560 Sep 21 2022 echo + -rwxr-xr-x 1 root root 41 Jan 25 04:43 egrep + -rwxr-xr-x 1 root root 67548 Sep 21 2022 false + -rwxr-xr-x 1 root root 41 Jan 25 04:43 fgrep + -rwxr-xr-x 1 root root 55748 Mar 23 23:02 findmnt + -rwsr-xr-x 1 root root 26208 Mar 23 22:15 fusermount + -rwxr-xr-x 1 root root 128608 Jan 25 04:43 grep + -rwxr-xr-x 2 root root 2346 Apr 10 2022 gunzip + -rwxr-xr-x 1 root root 6447 Apr 10 2022 gzexe + -rwxr-xr-x 1 root root 64220 Apr 10 2022 gzip + -rwxr-xr-x 1 root root 67032 Dec 20 03:33 hostname + -rwxr-xr-x 1 root root 67720 Sep 21 2022 ln + -rwxr-xr-x 1 root root 35132 Mar 23 23:51 login + -rwxr-xr-x 1 root root 133632 Sep 21 2022 ls + -rwxr-xr-x 1 root root 136808 Mar 23 23:02 lsblk + -rwxr-xr-x 1 root root 67800 Sep 21 2022 mkdir + -rwxr-xr-x 1 root root 67764 Sep 21 2022 mknod + -rwxr-xr-x 1 root root 67596 Sep 21 2022 mktemp + -rwxr-xr-x 1 root root 38504 Mar 23 23:02 more + -rwsr-xr-x 1 root root 38496 Mar 23 23:02 mount + -rwxr-xr-x 1 root root 9824 Mar 23 23:02 mountpoint + -rwxr-xr-x 1 root root 133532 Sep 21 2022 mv + lrwxrwxrwx 1 root root 8 Dec 20 03:33 nisdomainname -> hostname + lrwxrwxrwx 1 root root 14 Apr 3 20:25 pidof -> /sbin/killall5 + -rwxr-xr-x 1 root root 67608 Sep 21 2022 pwd + lrwxrwxrwx 1 root root 4 Apr 24 11:24 rbash -> bash + -rwxr-xr-x 1 root root 67600 Sep 21 2022 readlink + -rwxr-xr-x 1 root root 67672 Sep 21 2022 rm + -rwxr-xr-x 1 root root 67600 Sep 21 2022 rmdir + -rwxr-xr-x 1 root root 67400 Nov 3 2022 run-parts + -rwxr-xr-x 1 root root 133372 Jan 6 09:55 sed + lrwxrwxrwx 1 root root 9 May 23 23:43 sh -> /bin/bash + -rwxr-xr-x 1 root root 67584 Sep 21 2022 sleep + -rwxr-xr-x 1 root root 67644 Sep 21 2022 stty + -rwsr-xr-x 1 root root 50800 Mar 23 23:02 su + -rwxr-xr-x 1 root root 67584 Sep 21 2022 sync + -rwxr-xr-x 1 root root 336764 Apr 7 04:25 tar + -rwxr-xr-x 1 root root 67144 Nov 3 2022 tempfile + -rwxr-xr-x 1 root root 133224 Sep 21 2022 touch + -rwxr-xr-x 1 root root 67548 Sep 21 2022 true + -rwxr-xr-x 1 root root 9768 Mar 23 22:15 ulockmgr_server + -rwsr-xr-x 1 root root 22108 Mar 23 23:02 umount + -rwxr-xr-x 1 root root 67572 Sep 21 2022 uname + -rwxr-xr-x 2 root root 2346 Apr 10 2022 uncompress + -rwxr-xr-x 1 root root 133632 Sep 21 2022 vdir + -rwxr-xr-x 1 root root 42608 Mar 23 23:02 wdctl + lrwxrwxrwx 1 root root 8 Dec 20 03:33 ypdomainname -> hostname + -rwxr-xr-x 1 root root 1984 Apr 10 2022 zcat + -rwxr-xr-x 1 root root 1678 Apr 10 2022 zcmp + -rwxr-xr-x 1 root root 6460 Apr 10 2022 zdiff + -rwxr-xr-x 1 root root 29 Apr 10 2022 zegrep + -rwxr-xr-x 1 root root 29 Apr 10 2022 zfgrep + -rwxr-xr-x 1 root root 2081 Apr 10 2022 zforce + -rwxr-xr-x 1 root root 8103 Apr 10 2022 zgrep + -rwxr-xr-x 1 root root 2206 Apr 10 2022 zless + -rwxr-xr-x 1 root root 1842 Apr 10 2022 zmore + -rwxr-xr-x 1 root root 4577 Apr 10 2022 znew +I: user script /srv/workspace/pbuilder/32694/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy @@ -369,7 +401,7 @@ Get: 156 http://deb.debian.org/debian bookworm/main armhf ruby-rspec-expectations all 3.12.0c0e1m1s0-1 [89.5 kB] Get: 157 http://deb.debian.org/debian bookworm/main armhf ruby-rspec-mocks all 3.12.0c0e1m1s0-1 [79.5 kB] Get: 158 http://deb.debian.org/debian bookworm/main armhf ruby-rspec all 3.12.0c0e1m1s0-1 [5084 B] -Fetched 46.5 MB in 6s (7234 kB/s) +Fetched 46.5 MB in 1s (31.5 MB/s) debconf: delaying package configuration, since apt-utils is not installed Selecting previously unselected package libpython3.11-minimal:armhf. (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 ... 19329 files and directories currently installed.) @@ -1024,8 +1056,19 @@ Writing extended state information... Building tag database... -> Finished parsing the build-deps +Reading package lists... +Building dependency tree... +Reading state information... +usrmerge is already the newest version (35). +0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded. I: Building the package -I: Running cd /build/ruby-omniauth-2.1.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 > ../ruby-omniauth_2.1.1-1_source.changes +I: user script /srv/workspace/pbuilder/32694/tmp/hooks/A99_set_merged_usr starting +Re-configuring usrmerge... +removed '/etc/unsupported-skip-usrmerge-conversion' +The system has been successfully converted. +I: user script /srv/workspace/pbuilder/32694/tmp/hooks/A99_set_merged_usr finished +hostname: Name or service not known +I: Running cd /build/ruby-omniauth-2.1.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 > ../ruby-omniauth_2.1.1-1_source.changes dpkg-buildpackage: info: source package ruby-omniauth dpkg-buildpackage: info: source version 2.1.1-1 dpkg-buildpackage: info: source distribution unstable @@ -1058,7 +1101,7 @@ dh_prep -O--buildsystem=ruby dh_auto_install --destdir=debian/ruby-omniauth/ -O--buildsystem=ruby dh_ruby --install /build/ruby-omniauth-2.1.1/debian/ruby-omniauth -/usr/bin/ruby3.1 -S gem build --config-file /dev/null --verbose /tmp/d20230522-27771-3eqjf9/gemspec +/usr/bin/ruby3.1 -S gem build --config-file /dev/null --verbose /tmp/d20230523-5814-hll5ys/gemspec Failed to load /dev/null because it doesn't contain valid YAML hash WARNING: description and summary are identical WARNING: open-ended dependency on hashie (>= 3.4.6) is not recommended @@ -1074,7 +1117,7 @@ Name: omniauth Version: 2.1.1 File: omniauth-2.1.1.gem -/usr/bin/ruby3.1 -S gem install --config-file /dev/null --verbose --local --verbose --no-document --ignore-dependencies --install-dir debian/ruby-omniauth/usr/share/rubygems-integration/all /tmp/d20230522-27771-3eqjf9/omniauth-2.1.1.gem +/usr/bin/ruby3.1 -S gem install --config-file /dev/null --verbose --local --verbose --no-document --ignore-dependencies --install-dir debian/ruby-omniauth/usr/share/rubygems-integration/all /tmp/d20230523-5814-hll5ys/omniauth-2.1.1.gem Failed to load /dev/null because it doesn't contain valid YAML hash /build/ruby-omniauth-2.1.1/debian/ruby-omniauth/usr/share/rubygems-integration/all/gems/omniauth-2.1.1/lib/omniauth.rb /build/ruby-omniauth-2.1.1/debian/ruby-omniauth/usr/share/rubygems-integration/all/gems/omniauth-2.1.1/lib/omniauth/auth_hash.rb @@ -1121,151 +1164,135 @@ RUBYLIB=. GEM_PATH=/build/ruby-omniauth-2.1.1/debian/ruby-omniauth/usr/share/rubygems-integration/all:/build/ruby-omniauth-2.1.1/debian/.debhelper/generated/_source/home/.local/share/gem/ruby/3.1.0:/var/lib/gems/3.1.0:/usr/local/lib/ruby/gems/3.1.0:/usr/lib/ruby/gems/3.1.0:/usr/lib/arm-linux-gnueabihf/ruby/gems/3.1.0:/usr/share/rubygems-integration/3.1.0:/usr/share/rubygems-integration/all:/usr/lib/arm-linux-gnueabihf/rubygems-integration/3.1.0 ruby3.1 -S rake -f debian/ruby-tests.rake /usr/bin/ruby3.1 -I/usr/share/rubygems-integration/all/gems/rspec-support-3.12.0/lib:/usr/share/rubygems-integration/all/gems/rspec-core-3.12.0/lib /usr/share/rubygems-integration/all/gems/rspec-core-3.12.0/exe/rspec --pattern ./spec/\*\*/\*_spec.rb --format documentation -Randomized with seed 38052 +Randomized with seed 53554 -OmniAuth::AuthHash - has a subkey_class - does not try to parse `string` as InfoHash - converts a supplied info key into an InfoHash object - #name - falls back to go to first_name last_name concatenation - displays the nickname if no name, first, or last is available - displays the email if no name, first, last, or nick is available - defaults to the name key - displays only a first or last name if only that is available - OmniAuth::AuthHash::InfoHash - has a subkey_class - with Hashie 3.5.1+ - does not log anything in Hashie 3.5.1+ - #valid? - is valid if there is a name - #valid? - requires a provider - requires a name in the user info hash - is valid with the right parameters - requires a uid - #to_hash - does not pollute the URL hash with 'name' etc - is a plain old hash - supplies the calculated name in the converted hash - has string keys - converts an info hash as well +OmniAuth::FailureEndpoint + raise-out environment + raises out the error + raises out an OmniAuth::Error if no omniauth.error is set + non-raise-out environment + respects the globally configured path prefix + is a redirect + includes the SCRIPT_NAME + escapes the message key + respects the custom path prefix configured on the strategy + includes the origin (escaped) if one is provided OmniAuth::Strategy inherits by merging with preference for the latest class - is the current class's proc call if one exists - is the current class's proc call if one exists inherits by merging with preference for the latest class inherits by merging with preference for the latest class is the current class's proc call if one exists - #callback_phase - sets the auth hash - #call - raises NoSessionError if rack.session isn't set - duplicates and calls - fetcher stacks - .uid_stack - is an array of called ancestral procs - .info_stack - is an array of called ancestral procs - .credentials_stack - is an array of called ancestral procs - .extra_stack - is an array of called ancestral procs + is the current class's proc call if one exists + is the current class's proc call if one exists #call calls fail! when encountering an unhandled exception redirects to the fail! result when encountering an unhandled exception - custom prefix - uses a custom prefix for request - uses a custom prefix for callback + with relative url root + accepts the request + accepts the callback + error during auth phase + passes the error to fail!() + callback_url + redirects to the correctly prefixed callback + custom request + does not prefix a custom request path + error during call_app! + raises the application error + default paths + uses the default request path + strips trailing spaces on request + strips trailing spaces on callback + is case insensitive on callback path + uses the default callback path + is case insensitive on request path callback_url preserves the query parameters - uses a custom prefix - when in test mode and path not on request path - does not verify token + uses the default callback_path + consider script name + :form option + calls through to the app if :form => true is set as an option + calls through to the supplied form option if one exists test mode - sets omniauth.params with query params on the request phase - responds with the default hash if none is set - simulates login failure if mocked data is set as a symbol - responds with a provider-specific hash if one is set - redirects on failure - turns omniauth.origin into an env variable on the callback phase - respects SCRIPT_NAME (a.k.a. BaseURI) + is case insensitive on callback path maintains host and port - maintains query string parameters - turns omniauth.params into an env variable on the callback phase - is case insensitive on request path + respects SCRIPT_NAME (a.k.a. BaseURI) on failure + sets omniauth.params with query params on the request phase executes callback hook on the callback phase + respects SCRIPT_NAME (a.k.a. BaseURI) + simulates login failure if mocked data is set as a symbol rescues errors in request_call + responds with a provider-specific hash if one is set executes request hook on the request phase - respects SCRIPT_NAME (a.k.a. BaseURI) on failure - short circuits the request phase entirely - is case insensitive on callback path + does not short circuit requests outside of authentication does not set body parameters of POST request on the request phase + redirects on failure + is case insensitive on request path + responds with the default hash if none is set + turns omniauth.params into an env variable on the callback phase doesn't short circuit the request if request method is not allowed - does not short circuit requests outside of authentication + maintains query string parameters + short circuits the request phase entirely + turns omniauth.origin into an env variable on the callback phase omniauth.origin - custom - sets omniauth.origin from a custom param disabled does not set omniauth.origin + custom + sets omniauth.origin from a custom param default flow - sets omniauth.origin from the params if provided sets omniauth.origin to the HTTP_REFERER on the request phase by default + sets omniauth.origin from the params if provided + authenticity validation + with default POST only request methods + does not allow a request without a matching authenticity token + allows a request with matching authenticity_token + with custom allow_if proc + allows a valid request + with allowed GET + allows a request without authenticity token + warning message logging + logs warning message + when not login path is requested + does not log warning message omniauth.origin + custom + sets from a custom param default flow + is turned into an env variable on the callback phase is set on the request phase - is set on the failure env sets from the params if provided - is turned into an env variable on the callback phase + is set on the failure env with script_name - is set on the request phase, containing full path is turned into an env variable on the callback phase, containing full path + is set on the request phase, containing full path disabled does not set omniauth.origin - custom - sets from a custom param - custom paths - uses a custom request_path if one is provided - uses a custom callback_path if one is provided - callback_url - preserves the query parameters - uses a custom callback_path if one is provided - default paths - strips trailing spaces on request - uses the default callback path - uses the default request path - strips trailing spaces on callback - is case insensitive on callback path - is case insensitive on request path - callback_url - consider script name - preserves the query parameters - uses the default callback_path dynamic paths - runs the callback phase if the custom callback path evaluator is truthy + correctly reports the callback path when the custom callback path evaluator is truthy runs the request phase if the custom request path evaluator is truthy + runs the callback phase if the custom callback path evaluator is truthy provides a custom callback path if request_path evals to a string - correctly reports the callback path when the custom callback path evaluator is truthy - with relative url root - accepts the request - accepts the callback - error during auth phase - passes the error to fail!() - callback_url - redirects to the correctly prefixed callback - error during call_app! - raises the application error - custom request - does not prefix a custom request path request method restriction - does not allow a request method of the wrong type allows a request method of the correct type + does not allow a request method of the wrong type + receiving an OPTIONS request + to the request path + behaves like an OPTIONS request + responds with 200 + sets the Allow header properly + to the request path + behaves like an OPTIONS request + sets the Allow header properly + responds with 200 + to some other path + does not short-circuit the request + when in test mode and path not on request path + does not verify token custom full_host - honors HTTP_X_FORWARDED_PROTO if present + is the string when a string is there is based on the request if it's not a string nor a proc runs the proc with the env when it is a proc - is the string when a string is there + honors HTTP_X_FORWARDED_PROTO if present options mutation in callback phase does not affect original options @@ -1273,193 +1300,209 @@ in request phase does not affect deep options does not affect original options - authenticity validation - with allowed GET - allows a request without authenticity token - warning message logging - logs warning message - when not login path is requested - does not log warning message - with default POST only request methods - does not allow a request without a matching authenticity token - allows a request with matching authenticity_token - with custom allow_if proc - allows a valid request - :form option - calls through to the supplied form option if one exists - calls through to the app if :form => true is set as an option - receiving an OPTIONS request - to the request path - behaves like an OPTIONS request - sets the Allow header properly - responds with 200 - to some other path - does not short-circuit the request - to the request path - behaves like an OPTIONS request - sets the Allow header properly - responds with 200 - #initialize - options extraction - is the last argument if the last argument is a Hash - is the default options if any are provided - custom args - sets options based on the arguments if they are supplied - #auth_hash - calls through to uid, info, credentials, and extra - returns an AuthHash + custom prefix + uses a custom prefix for request + uses a custom prefix for callback + callback_url + preserves the query parameters + uses a custom prefix + custom paths + uses a custom request_path if one is provided + uses a custom callback_path if one is provided + callback_url + preserves the query parameters + uses a custom callback_path if one is provided + #full_host + remains calm when there is a pipe in the URL + #uid + is the current class's uid if one exists + inherits if it can + #call + duplicates and calls + raises NoSessionError if rack.session isn't set + #callback_phase + sets the auth hash #redirect uses javascript if :iframe is true (PENDING: Temporarily skipped with xit) - #inspect - returns the class name + fetcher stacks + .extra_stack + is an array of called ancestral procs + .credentials_stack + is an array of called ancestral procs + .uid_stack + is an array of called ancestral procs + .info_stack + is an array of called ancestral procs setup phase when options[:setup] is an app calls the rack app does not call the app on a non-omniauth endpoint when options[:setup] = true - does not call through on a non-omniauth endpoint calls through to /auth/:provider/setup - request_phase - raises a NotImplementedError - .args - accepts corresponding options as default arg values - sets args to the specified argument if there is one - is inheritable + does not call through on a non-omniauth endpoint + #fail! + provides exception information when one is provided + provides a generic message when not provided an exception fetcher procs - .credentials - sets and retrieve a proc - .extra - sets and retrieve a proc .uid sets and retrieve a proc .info sets and retrieve a proc - #uid - is the current class's uid if one exists - inherits if it can - user_info - should default to an empty hash - #fail! - provides exception information when one is provided - provides a generic message when not provided an exception - #full_host - remains calm when there is a pipe in the URL + .extra + sets and retrieve a proc + .credentials + sets and retrieve a proc + .option + sets the default value to nil if none is provided + sets a default value + #initialize + options extraction + is the last argument if the last argument is a Hash + is the default options if any are provided + custom args + sets options based on the arguments if they are supplied + .args + is inheritable + sets args to the specified argument if there is one + accepts corresponding options as default arg values .default_options is inherited from a parent class + request_phase + raises a NotImplementedError + #auth_hash + calls through to uid, info, credentials, and extra + returns an AuthHash .configure takes a hash and deep merge it when block is passed works when block doesn't evaluate to true allows for default options setting + user_info + should default to an empty hash + #inspect + returns the class name #skip_info? is true if options.skip_info is true - is false by default - is false if options.skip_info is false is true if options.skip_info is a callable that evaluates to truthy - .option - sets the default value to nil if none is provided - sets a default value + is false if options.skip_info is false + is false by default + +OmniAuth::AuthHash + converts a supplied info key into an InfoHash object + does not try to parse `string` as InfoHash + has a subkey_class + #name + displays only a first or last name if only that is available + falls back to go to first_name last_name concatenation + displays the email if no name, first, last, or nick is available + displays the nickname if no name, first, or last is available + defaults to the name key + #to_hash + supplies the calculated name in the converted hash + has string keys + does not pollute the URL hash with 'name' etc + is a plain old hash + converts an info hash as well + OmniAuth::AuthHash::InfoHash + has a subkey_class + #valid? + is valid if there is a name + with Hashie 3.5.1+ + does not log anything in Hashie 3.5.1+ + #valid? + requires a name in the user info hash + requires a provider + is valid with the right parameters + requires a uid + +OmniAuth::KeyStore + on Hashie 3.5.2+ + does not log anything to the console + on Hashie 3.5.0 and 3.5.1 + does not log anything to the console + on Hashie < 3.5.0 + does not log anything to the console OmniAuth::Strategies::Developer - request phase - has the callback as the action for the form - has a text field for each of the fields - displays a form callback phase with default options + sets the name in the auth hash sets the email in the auth hash sets the uid to the email - sets the name in the auth hash with custom options - sets the uid properly sets info fields properly - -OmniAuth::Form - fieldset - creates a fieldset with options - #initialize - sets an H1 tag from the passed :title option - sets the form action to the passed :url option - #password_field - adds a labeled input field - #html - appends to the html body - .build - evaluates in the instance when called with a block and no argument - yields the instance when called with a block and argument + sets the uid properly + request phase + has a text field for each of the fields + has the callback as the action for the form + displays a form OmniAuth .strategies increases when a new strategy is made + .logger + calls through to the configured logger + ::Utils + .camelize + works in special cases that have been added + works on normal cases + doesn't uppercase the first letter when passed false + replaces / with :: + .deep_merge + combines hashes + form_css + returns a style tag with the configured form_css configuration - is able to set hook on request_call is able to set request_validation_phase - is able to set hook on callback_call + is able to set the path + is able to set hook on request_call + is able to set hook on option_call is callable from .configure + is able to set hook on callback_call is able to set the on_failure rack app - is able to set hook on option_call - is able to set the path mock auth facebook is AuthHash - default is AuthHash sets facebook attributes does not mutate given auth hash + default is AuthHash .defaults is a hash of default configuration - ::Utils - .camelize - replaces / with :: - works on normal cases - doesn't uppercase the first letter when passed false - works in special cases that have been added - form_css - returns a style tag with the configured form_css - .deep_merge - combines hashes - .logger - calls through to the configured logger OmniAuth::Builder - #before_callback_phase - passes the block to the config - #configure + #before_request_phase passes the block to the config #before_options_phase passes the block to the config - #on_failure - passes the block to the config #provider + doesn't translate a symbol to a top-level constant accepts a class raises a helpful LoadError message if it can't find the class translates a symbol to a constant - doesn't translate a symbol to a top-level constant + #on_failure + passes the block to the config + #configure + passes the block to the config + #before_callback_phase + passes the block to the config #call passes env to to_app.call #options merges provided options in adds an argument if no options are provided - #before_request_phase - passes the block to the config - -OmniAuth::KeyStore - on Hashie < 3.5.0 - does not log anything to the console - on Hashie 3.5.0 and 3.5.1 - does not log anything to the console - on Hashie 3.5.2+ - does not log anything to the console -OmniAuth::FailureEndpoint - raise-out environment - raises out an OmniAuth::Error if no omniauth.error is set - raises out the error - non-raise-out environment - respects the custom path prefix configured on the strategy - is a redirect - escapes the message key - respects the globally configured path prefix - includes the SCRIPT_NAME - includes the origin (escaped) if one is provided +OmniAuth::Form + #html + appends to the html body + #initialize + sets an H1 tag from the passed :title option + sets the form action to the passed :url option + #password_field + adds a labeled input field + fieldset + creates a fieldset with options + .build + yields the instance when called with a block and argument + evaluates in the instance when called with a block and no argument Pending: (Failures listed here are expected and do not affect your suite's status) @@ -1467,10 +1510,10 @@ # Temporarily skipped with xit # ./spec/omniauth/strategy_spec.rb:278 -Finished in 2.34 seconds (files took 4.24 seconds to load) +Finished in 0.64008 seconds (files took 1.09 seconds to load) 211 examples, 0 failures, 1 pending -Randomized with seed 38052 +Randomized with seed 53554 ┌──────────────────────────────────────────────────────────────────────────────┐ @@ -1502,12 +1545,14 @@ dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: including full source code in upload I: copying local configuration +I: user script /srv/workspace/pbuilder/32694/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/32694/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/13758 and its subdirectories -I: Current time: Mon May 22 21:42:54 -12 2023 -I: pbuilder-time-stamp: 1684834974 +I: removing directory /srv/workspace/pbuilder/32694 and its subdirectories +I: Current time: Tue May 23 23:45:07 +14 2023 +I: pbuilder-time-stamp: 1684835107