Diff of the two buildlogs:

--
--- b1/build.log	2021-06-07 15:08:49.356102083 +0000
+++ b2/build.log	2021-06-07 15:13:22.969487515 +0000
@@ -1,6 +1,6 @@
 I: pbuilder: network access will be disabled during build
-I: Current time: Sun Jul 10 09:31:19 -12 2022
-I: pbuilder-time-stamp: 1657488679
+I: Current time: Tue Jun  8 05:08:54 +14 2021
+I: pbuilder-time-stamp: 1623078534
 I: Building the build Environment
 I: extracting base tarball [/var/cache/pbuilder/bullseye-reproducible-base.tgz]
 I: copying local configuration
@@ -17,8 +17,8 @@
 I: copying [./ruby-http-2_0.10.2-1.debian.tar.xz]
 I: Extracting source
 gpgv: unknown type of key resource 'trustedkeys.kbx'
-gpgv: keyblock resource '/tmp/dpkg-verify-sig.RYlXhxYV/trustedkeys.kbx': General error
-gpgv: Signature made Wed Jun 24 09:27:02 2020 -12
+gpgv: keyblock resource '/tmp/dpkg-verify-sig.3eZjRJC0/trustedkeys.kbx': General error
+gpgv: Signature made Thu Jun 25 11:27:02 2020 +14
 gpgv:                using RSA key 58E1222F9696C885A3CD104C5D328D082AAAB140
 gpgv: Can't check signature: No public key
 dpkg-source: warning: failed to verify signature on ./ruby-http-2_0.10.2-1.dsc
@@ -29,137 +29,171 @@
 dpkg-source: info: applying 0001-Drop-spec-hpack_test_spec.rb-since-there-is-no-raw-d.patch
 I: Not using root during the build.
 I: Installing the build-deps
-I: user script /srv/workspace/pbuilder/13054/tmp/hooks/D02_print_environment starting
+I: user script /srv/workspace/pbuilder/5076/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
+Removing 'diversion of /bin/sh to /bin/sh.distrib by dash'
+Adding 'diversion of /bin/sh to /bin/sh.distrib by bash'
+Removing 'diversion of /usr/share/man/man1/sh.1.gz to /usr/share/man/man1/sh.distrib.1.gz by dash'
+Adding 'diversion of /usr/share/man/man1/sh.1.gz to /usr/share/man/man1/sh.distrib.1.gz by 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/5076/tmp/hooks/D01_modify_environment finished
+I: user script /srv/workspace/pbuilder/5076/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='i386'
-  DEBIAN_FRONTEND='noninteractive'
-  DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all,-fixfilepath parallel=18'
-  DISTRIBUTION=''
-  HOME='/root'
-  HOST_ARCH='i386'
+  BASH=/bin/sh
+  BASHOPTS=checkwinsize:cmdhist:complete_fullquote:extquote:force_fignore:globasciiranges:hostcomplete:interactive_comments:progcomp:promptvars:sourcepath
+  BASH_ALIASES=()
+  BASH_ARGC=()
+  BASH_ARGV=()
+  BASH_CMDS=()
+  BASH_LINENO=([0]="12" [1]="0")
+  BASH_SOURCE=([0]="/tmp/hooks/D02_print_environment" [1]="/tmp/hooks/D02_print_environment")
+  BASH_VERSINFO=([0]="5" [1]="1" [2]="4" [3]="1" [4]="release" [5]="i686-pc-linux-gnu")
+  BASH_VERSION='5.1.4(1)-release'
+  BUILDDIR=/build
+  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,-fixfilepath parallel=10'
+  DIRSTACK=()
+  DISTRIBUTION=
+  EUID=0
+  FUNCNAME=([0]="Echo" [1]="main")
+  GROUPS=()
+  HOME=/root
+  HOSTNAME=i-capture-the-hostname
+  HOSTTYPE=i686
+  HOST_ARCH=i386
   IFS=' 	
   '
-  INVOCATION_ID='f1c51a0acee24924a01692006198f3a0'
-  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='13054'
-  PS1='# '
-  PS2='> '
+  INVOCATION_ID=be872f4025be4173a779fac122595826
+  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=5076
   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/tmp.9foezAuk9C/pbuilderrc_zucc --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/bullseye-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/tmp.9foezAuk9C/b1 --logfile b1/build.log ruby-http-2_0.10.2-1.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://85.184.249.68: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/tmp.9foezAuk9C/pbuilderrc_oZea --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/bullseye-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/tmp.9foezAuk9C/b2 --logfile b2/build.log --extrapackages usrmerge ruby-http-2_0.10.2-1.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://78.137.99.97:3128
 I: uname -a
-  Linux ionos16-i386 4.19.0-16-amd64 #1 SMP Debian 4.19.181-1 (2021-03-19) x86_64 GNU/Linux
+  Linux i-capture-the-hostname 4.19.0-16-686-pae #1 SMP Debian 4.19.181-1 (2021-03-19) i686 GNU/Linux
 I: ls -l /bin
   total 5776
-  -rwxr-xr-x 1 root root 1367848 Feb 24  2021 bash
-  -rwxr-xr-x 3 root root   38280 Jul 20  2020 bunzip2
-  -rwxr-xr-x 3 root root   38280 Jul 20  2020 bzcat
-  lrwxrwxrwx 1 root root       6 Jul 20  2020 bzcmp -> bzdiff
-  -rwxr-xr-x 1 root root    2225 Jul 20  2020 bzdiff
-  lrwxrwxrwx 1 root root       6 Jul 20  2020 bzegrep -> bzgrep
-  -rwxr-xr-x 1 root root    4877 Sep  4  2019 bzexe
-  lrwxrwxrwx 1 root root       6 Jul 20  2020 bzfgrep -> bzgrep
-  -rwxr-xr-x 1 root root    3775 Jul 20  2020 bzgrep
-  -rwxr-xr-x 3 root root   38280 Jul 20  2020 bzip2
-  -rwxr-xr-x 1 root root   17768 Jul 20  2020 bzip2recover
-  lrwxrwxrwx 1 root root       6 Jul 20  2020 bzless -> bzmore
-  -rwxr-xr-x 1 root root    1297 Jul 20  2020 bzmore
-  -rwxr-xr-x 1 root root   38824 Sep 22  2020 cat
-  -rwxr-xr-x 1 root root   71624 Sep 22  2020 chgrp
-  -rwxr-xr-x 1 root root   67528 Sep 22  2020 chmod
-  -rwxr-xr-x 1 root root   75752 Sep 22  2020 chown
-  -rwxr-xr-x 1 root root  157960 Sep 22  2020 cp
-  -rwxr-xr-x 1 root root  128724 Dec 10  2020 dash
-  -rwxr-xr-x 1 root root  124904 Sep 22  2020 date
-  -rwxr-xr-x 1 root root   92172 Sep 22  2020 dd
-  -rwxr-xr-x 1 root root  100752 Sep 22  2020 df
-  -rwxr-xr-x 1 root root  153964 Sep 22  2020 dir
-  -rwxr-xr-x 1 root root   83644 Feb  7  2021 dmesg
-  lrwxrwxrwx 1 root root       8 Nov  6  2019 dnsdomainname -> hostname
-  lrwxrwxrwx 1 root root       8 Nov  6  2019 domainname -> hostname
-  -rwxr-xr-x 1 root root   34664 Sep 22  2020 echo
-  -rwxr-xr-x 1 root root      28 Nov  9  2020 egrep
-  -rwxr-xr-x 1 root root   34664 Sep 22  2020 false
-  -rwxr-xr-x 1 root root      28 Nov  9  2020 fgrep
-  -rwxr-xr-x 1 root root   71928 Feb  7  2021 findmnt
-  -rwsr-xr-x 1 root root   30112 Feb 26  2021 fusermount
-  -rwxr-xr-x 1 root root  210488 Nov  9  2020 grep
-  -rwxr-xr-x 2 root root    2346 Mar  2  2021 gunzip
-  -rwxr-xr-x 1 root root    6376 Mar  2  2021 gzexe
-  -rwxr-xr-x 1 root root  100952 Mar  2  2021 gzip
-  -rwxr-xr-x 1 root root   21916 Nov  6  2019 hostname
-  -rwxr-xr-x 1 root root   83980 Sep 22  2020 ln
-  -rwxr-xr-x 1 root root   55572 Feb  7  2020 login
-  -rwxr-xr-x 1 root root  153964 Sep 22  2020 ls
-  -rwxr-xr-x 1 root root  153124 Feb  7  2021 lsblk
-  -rwxr-xr-x 1 root root   96328 Sep 22  2020 mkdir
-  -rwxr-xr-x 1 root root   79912 Sep 22  2020 mknod
-  -rwxr-xr-x 1 root root   47048 Sep 22  2020 mktemp
-  -rwxr-xr-x 1 root root   58920 Feb  7  2021 more
-  -rwsr-xr-x 1 root root   50720 Feb  7  2021 mount
-  -rwxr-xr-x 1 root root   13856 Feb  7  2021 mountpoint
-  -rwxr-xr-x 1 root root  157996 Sep 22  2020 mv
-  lrwxrwxrwx 1 root root       8 Nov  6  2019 nisdomainname -> hostname
-  lrwxrwxrwx 1 root root      14 Apr 18  2021 pidof -> /sbin/killall5
-  -rwxr-xr-x 1 root root   38824 Sep 22  2020 pwd
-  lrwxrwxrwx 1 root root       4 Feb 24  2021 rbash -> bash
-  -rwxr-xr-x 1 root root   46984 Sep 22  2020 readlink
-  -rwxr-xr-x 1 root root   75720 Sep 22  2020 rm
-  -rwxr-xr-x 1 root root   46984 Sep 22  2020 rmdir
-  -rwxr-xr-x 1 root root   22292 Sep 27  2020 run-parts
-  -rwxr-xr-x 1 root root  125036 Dec 22  2018 sed
-  lrwxrwxrwx 1 root root       4 Jul  7 03:46 sh -> dash
-  -rwxr-xr-x 1 root root   34696 Sep 22  2020 sleep
-  -rwxr-xr-x 1 root root   83880 Sep 22  2020 stty
-  -rwsr-xr-x 1 root root   79396 Feb  7  2021 su
-  -rwxr-xr-x 1 root root   34696 Sep 22  2020 sync
-  -rwxr-xr-x 1 root root  602584 Feb 16  2021 tar
-  -rwxr-xr-x 1 root root   13860 Sep 27  2020 tempfile
-  -rwxr-xr-x 1 root root  108520 Sep 22  2020 touch
-  -rwxr-xr-x 1 root root   34664 Sep 22  2020 true
-  -rwxr-xr-x 1 root root   17768 Feb 26  2021 ulockmgr_server
-  -rwsr-xr-x 1 root root   30236 Feb  7  2021 umount
-  -rwxr-xr-x 1 root root   34664 Sep 22  2020 uname
-  -rwxr-xr-x 2 root root    2346 Mar  2  2021 uncompress
-  -rwxr-xr-x 1 root root  153964 Sep 22  2020 vdir
-  -rwxr-xr-x 1 root root   63024 Feb  7  2021 wdctl
-  lrwxrwxrwx 1 root root       8 Nov  6  2019 ypdomainname -> hostname
-  -rwxr-xr-x 1 root root    1984 Mar  2  2021 zcat
-  -rwxr-xr-x 1 root root    1678 Mar  2  2021 zcmp
-  -rwxr-xr-x 1 root root    5880 Mar  2  2021 zdiff
-  -rwxr-xr-x 1 root root      29 Mar  2  2021 zegrep
-  -rwxr-xr-x 1 root root      29 Mar  2  2021 zfgrep
-  -rwxr-xr-x 1 root root    2081 Mar  2  2021 zforce
-  -rwxr-xr-x 1 root root    7585 Mar  2  2021 zgrep
-  -rwxr-xr-x 1 root root    2206 Mar  2  2021 zless
-  -rwxr-xr-x 1 root root    1842 Mar  2  2021 zmore
-  -rwxr-xr-x 1 root root    4553 Mar  2  2021 znew
-I: user script /srv/workspace/pbuilder/13054/tmp/hooks/D02_print_environment finished
+  -rwxr-xr-x 1 root root 1367848 Feb 25 10:57 bash
+  -rwxr-xr-x 3 root root   38280 Jul 21  2020 bunzip2
+  -rwxr-xr-x 3 root root   38280 Jul 21  2020 bzcat
+  lrwxrwxrwx 1 root root       6 Jul 21  2020 bzcmp -> bzdiff
+  -rwxr-xr-x 1 root root    2225 Jul 21  2020 bzdiff
+  lrwxrwxrwx 1 root root       6 Jul 21  2020 bzegrep -> bzgrep
+  -rwxr-xr-x 1 root root    4877 Sep  5  2019 bzexe
+  lrwxrwxrwx 1 root root       6 Jul 21  2020 bzfgrep -> bzgrep
+  -rwxr-xr-x 1 root root    3775 Jul 21  2020 bzgrep
+  -rwxr-xr-x 3 root root   38280 Jul 21  2020 bzip2
+  -rwxr-xr-x 1 root root   17768 Jul 21  2020 bzip2recover
+  lrwxrwxrwx 1 root root       6 Jul 21  2020 bzless -> bzmore
+  -rwxr-xr-x 1 root root    1297 Jul 21  2020 bzmore
+  -rwxr-xr-x 1 root root   38824 Sep 23  2020 cat
+  -rwxr-xr-x 1 root root   71624 Sep 23  2020 chgrp
+  -rwxr-xr-x 1 root root   67528 Sep 23  2020 chmod
+  -rwxr-xr-x 1 root root   75752 Sep 23  2020 chown
+  -rwxr-xr-x 1 root root  157960 Sep 23  2020 cp
+  -rwxr-xr-x 1 root root  128724 Dec 11 03:23 dash
+  -rwxr-xr-x 1 root root  124904 Sep 23  2020 date
+  -rwxr-xr-x 1 root root   92172 Sep 23  2020 dd
+  -rwxr-xr-x 1 root root  100752 Sep 23  2020 df
+  -rwxr-xr-x 1 root root  153964 Sep 23  2020 dir
+  -rwxr-xr-x 1 root root   83644 Feb  8 04:38 dmesg
+  lrwxrwxrwx 1 root root       8 Nov  8  2019 dnsdomainname -> hostname
+  lrwxrwxrwx 1 root root       8 Nov  8  2019 domainname -> hostname
+  -rwxr-xr-x 1 root root   34664 Sep 23  2020 echo
+  -rwxr-xr-x 1 root root      28 Nov 10  2020 egrep
+  -rwxr-xr-x 1 root root   34664 Sep 23  2020 false
+  -rwxr-xr-x 1 root root      28 Nov 10  2020 fgrep
+  -rwxr-xr-x 1 root root   71928 Feb  8 04:38 findmnt
+  -rwsr-xr-x 1 root root   30112 Feb 27 06:12 fusermount
+  -rwxr-xr-x 1 root root  210488 Nov 10  2020 grep
+  -rwxr-xr-x 2 root root    2346 Mar  3 13:30 gunzip
+  -rwxr-xr-x 1 root root    6376 Mar  3 13:30 gzexe
+  -rwxr-xr-x 1 root root  100952 Mar  3 13:30 gzip
+  -rwxr-xr-x 1 root root   21916 Nov  8  2019 hostname
+  -rwxr-xr-x 1 root root   83980 Sep 23  2020 ln
+  -rwxr-xr-x 1 root root   55572 Feb  8  2020 login
+  -rwxr-xr-x 1 root root  153964 Sep 23  2020 ls
+  -rwxr-xr-x 1 root root  153124 Feb  8 04:38 lsblk
+  -rwxr-xr-x 1 root root   96328 Sep 23  2020 mkdir
+  -rwxr-xr-x 1 root root   79912 Sep 23  2020 mknod
+  -rwxr-xr-x 1 root root   47048 Sep 23  2020 mktemp
+  -rwxr-xr-x 1 root root   58920 Feb  8 04:38 more
+  -rwsr-xr-x 1 root root   50720 Feb  8 04:38 mount
+  -rwxr-xr-x 1 root root   13856 Feb  8 04:38 mountpoint
+  -rwxr-xr-x 1 root root  157996 Sep 23  2020 mv
+  lrwxrwxrwx 1 root root       8 Nov  8  2019 nisdomainname -> hostname
+  lrwxrwxrwx 1 root root      14 Apr 19 05:38 pidof -> /sbin/killall5
+  -rwxr-xr-x 1 root root   38824 Sep 23  2020 pwd
+  lrwxrwxrwx 1 root root       4 Feb 25 10:57 rbash -> bash
+  -rwxr-xr-x 1 root root   46984 Sep 23  2020 readlink
+  -rwxr-xr-x 1 root root   75720 Sep 23  2020 rm
+  -rwxr-xr-x 1 root root   46984 Sep 23  2020 rmdir
+  -rwxr-xr-x 1 root root   22292 Sep 28  2020 run-parts
+  -rwxr-xr-x 1 root root  125036 Dec 23  2018 sed
+  lrwxrwxrwx 1 root root       4 Jun  8 05:11 sh -> bash
+  lrwxrwxrwx 1 root root       4 Jun  4 23:26 sh.distrib -> dash
+  -rwxr-xr-x 1 root root   34696 Sep 23  2020 sleep
+  -rwxr-xr-x 1 root root   83880 Sep 23  2020 stty
+  -rwsr-xr-x 1 root root   79396 Feb  8 04:38 su
+  -rwxr-xr-x 1 root root   34696 Sep 23  2020 sync
+  -rwxr-xr-x 1 root root  602584 Feb 17 23:55 tar
+  -rwxr-xr-x 1 root root   13860 Sep 28  2020 tempfile
+  -rwxr-xr-x 1 root root  108520 Sep 23  2020 touch
+  -rwxr-xr-x 1 root root   34664 Sep 23  2020 true
+  -rwxr-xr-x 1 root root   17768 Feb 27 06:12 ulockmgr_server
+  -rwsr-xr-x 1 root root   30236 Feb  8 04:38 umount
+  -rwxr-xr-x 1 root root   34664 Sep 23  2020 uname
+  -rwxr-xr-x 2 root root    2346 Mar  3 13:30 uncompress
+  -rwxr-xr-x 1 root root  153964 Sep 23  2020 vdir
+  -rwxr-xr-x 1 root root   63024 Feb  8 04:38 wdctl
+  lrwxrwxrwx 1 root root       8 Nov  8  2019 ypdomainname -> hostname
+  -rwxr-xr-x 1 root root    1984 Mar  3 13:30 zcat
+  -rwxr-xr-x 1 root root    1678 Mar  3 13:30 zcmp
+  -rwxr-xr-x 1 root root    5880 Mar  3 13:30 zdiff
+  -rwxr-xr-x 1 root root      29 Mar  3 13:30 zegrep
+  -rwxr-xr-x 1 root root      29 Mar  3 13:30 zfgrep
+  -rwxr-xr-x 1 root root    2081 Mar  3 13:30 zforce
+  -rwxr-xr-x 1 root root    7585 Mar  3 13:30 zgrep
+  -rwxr-xr-x 1 root root    2206 Mar  3 13:30 zless
+  -rwxr-xr-x 1 root root    1842 Mar  3 13:30 zmore
+  -rwxr-xr-x 1 root root    4553 Mar  3 13:30 znew
+I: user script /srv/workspace/pbuilder/5076/tmp/hooks/D02_print_environment finished
  -> Attempting to satisfy build-dependencies
  -> Creating pbuilder-satisfydepends-dummy package
 Package: pbuilder-satisfydepends-dummy
@@ -358,7 +392,7 @@
 Get: 153 http://deb.debian.org/debian bullseye/main i386 ruby-rspec-expectations all 3.9.0c2e2m1s3-2 [89.9 kB]
 Get: 154 http://deb.debian.org/debian bullseye/main i386 ruby-rspec-mocks all 3.9.0c2e2m1s3-2 [81.4 kB]
 Get: 155 http://deb.debian.org/debian bullseye/main i386 ruby-rspec all 3.9.0c2e2m1s3-2 [8348 B]
-Fetched 46.4 MB in 1s (65.7 MB/s)
+Fetched 46.4 MB in 16s (2890 kB/s)
 debconf: delaying package configuration, since apt-utils is not installed
 Selecting previously unselected package bsdextrautils.
 (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 ... 19675 files and directories currently installed.)
@@ -1002,8 +1036,44 @@
 Writing extended state information...
 Building tag database...
  -> Finished parsing the build-deps
+Reading package lists...
+Building dependency tree...
+Reading state information...
+The following additional packages will be installed:
+  libfile-find-rule-perl libnumber-compare-perl libtext-glob-perl
+The following NEW packages will be installed:
+  libfile-find-rule-perl libnumber-compare-perl libtext-glob-perl usrmerge
+0 upgraded, 4 newly installed, 0 to remove and 0 not upgraded.
+Need to get 59.5 kB of archives.
+After this operation, 157 kB of additional disk space will be used.
+Get:1 http://deb.debian.org/debian bullseye/main i386 libnumber-compare-perl all 0.03-1.1 [6956 B]
+Get:2 http://deb.debian.org/debian bullseye/main i386 libtext-glob-perl all 0.11-1 [8888 B]
+Get:3 http://deb.debian.org/debian bullseye/main i386 libfile-find-rule-perl all 0.34-1 [30.6 kB]
+Get:4 http://deb.debian.org/debian bullseye/main i386 usrmerge all 25 [13.0 kB]
+debconf: delaying package configuration, since apt-utils is not installed
+Fetched 59.5 kB in 0s (683 kB/s)
+Selecting previously unselected package libnumber-compare-perl.
+(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 ... 27751 files and directories currently installed.)
+Preparing to unpack .../libnumber-compare-perl_0.03-1.1_all.deb ...
+Unpacking libnumber-compare-perl (0.03-1.1) ...
+Selecting previously unselected package libtext-glob-perl.
+Preparing to unpack .../libtext-glob-perl_0.11-1_all.deb ...
+Unpacking libtext-glob-perl (0.11-1) ...
+Selecting previously unselected package libfile-find-rule-perl.
+Preparing to unpack .../libfile-find-rule-perl_0.34-1_all.deb ...
+Unpacking libfile-find-rule-perl (0.34-1) ...
+Selecting previously unselected package usrmerge.
+Preparing to unpack .../archives/usrmerge_25_all.deb ...
+Unpacking usrmerge (25) ...
+Setting up libtext-glob-perl (0.11-1) ...
+Setting up libnumber-compare-perl (0.03-1.1) ...
+Setting up libfile-find-rule-perl (0.34-1) ...
+Setting up usrmerge (25) ...
+The system has been successfully converted.
+Processing triggers for man-db (2.9.4-2) ...
+Not building database; man-db/auto-update is not 'true'.
 I: Building the package
-I: Running cd /build/ruby-http-2-0.10.2/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-buildpackage -us -uc -b
+I: Running cd /build/ruby-http-2-0.10.2/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-buildpackage -us -uc -b
 dpkg-buildpackage: info: source package ruby-http-2
 dpkg-buildpackage: info: source version 0.10.2-1
 dpkg-buildpackage: info: source distribution unstable
@@ -1034,7 +1104,7 @@
    dh_auto_install -O--buildsystem=ruby
 	dh_ruby --install /build/ruby-http-2-0.10.2/debian/ruby-http-2
    dh_ruby --install
-/usr/bin/ruby2.7 -S gem build --config-file /dev/null --verbose /tmp/d20220710-25228-zbik0p/gemspec
+/usr/bin/ruby2.7 -S gem build --config-file /dev/null --verbose /tmp/d20210608-27198-1luzq6r/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 bundler (>= 0, development) is not recommended
@@ -1044,7 +1114,7 @@
   Name: http-2
   Version: 0.10.2
   File: http-2-0.10.2.gem
-/usr/bin/ruby2.7 -S gem install --config-file /dev/null --verbose --local --verbose --no-document --ignore-dependencies --install-dir debian/ruby-http-2/usr/share/rubygems-integration/all /tmp/d20220710-25228-zbik0p/http-2-0.10.2.gem
+/usr/bin/ruby2.7 -S gem install --config-file /dev/null --verbose --local --verbose --no-document --ignore-dependencies --install-dir debian/ruby-http-2/usr/share/rubygems-integration/all /tmp/d20210608-27198-1luzq6r/http-2-0.10.2.gem
 Failed to load /dev/null because it doesn't contain valid YAML hash
 /build/ruby-http-2-0.10.2/debian/ruby-http-2/usr/share/rubygems-integration/all/gems/http-2-0.10.2/example/Gemfile
 /build/ruby-http-2-0.10.2/debian/ruby-http-2/usr/share/rubygems-integration/all/gems/http-2-0.10.2/example/README.md
@@ -1080,7 +1150,7 @@
 rm -rf extensions
 cd gems/http-2-0.10.2
 rm -f 
-chmod 644 lib/tasks/generate_huffman_table.rb lib/http/2.rb lib/http/2/server.rb lib/http/2/flow_buffer.rb lib/http/2/stream.rb lib/http/2/client.rb lib/http/2/version.rb lib/http/2/buffer.rb lib/http/2/error.rb lib/http/2/huffman.rb lib/http/2/connection.rb lib/http/2/compressor.rb lib/http/2/framer.rb lib/http/2/emitter.rb lib/http/2/huffman_statemachine.rb
+chmod 644 lib/http/2/server.rb lib/http/2/version.rb lib/http/2/stream.rb lib/http/2/framer.rb lib/http/2/huffman_statemachine.rb lib/http/2/emitter.rb lib/http/2/flow_buffer.rb lib/http/2/huffman.rb lib/http/2/buffer.rb lib/http/2/error.rb lib/http/2/compressor.rb lib/http/2/client.rb lib/http/2/connection.rb lib/http/2.rb lib/tasks/generate_huffman_table.rb
 find lib/ -type d -empty -delete
 cd -
 cd -
@@ -1099,21 +1169,41 @@
 RUBYLIB=. GEM_PATH=/build/ruby-http-2-0.10.2/debian/ruby-http-2/usr/share/rubygems-integration/all:/build/ruby-http-2-0.10.2/debian/.debhelper/generated/_source/home/.local/share/gem/ruby/2.7.0:/var/lib/gems/2.7.0:/usr/local/lib/ruby/gems/2.7.0:/usr/lib/ruby/gems/2.7.0:/usr/lib/i386-linux-gnu/ruby/gems/2.7.0:/usr/share/rubygems-integration/2.7.0:/usr/share/rubygems-integration/all:/usr/lib/i386-linux-gnu/rubygems-integration/2.7.0 ruby2.7 -S rake -f debian/ruby-tests.rake
 /usr/bin/ruby2.7 -I/usr/share/rubygems-integration/all/gems/rspec-support-3.9.3/lib:/usr/share/rubygems-integration/all/gems/rspec-core-3.9.2/lib /usr/share/rubygems-integration/all/gems/rspec-core-3.9.2/exe/rspec --pattern ./spec/\*\*/\*_spec.rb --format documentation
 
-Randomized with seed 17860
+Randomized with seed 55665
 
-HTTP2::Buffer
-  should return bytesize of the buffer
-  should force 8-bit encoding
-  should force 8-bit encoding when adding data
-  should read single byte at a time
-  should unpack an unsigned 32-bit int
-
-HTTP2::Server
-  should allow server push
+HTTP2::Client
+  upgrade
+    sends the preface
+    initializes the first stream in the half-closed state
+    fails when client has already created streams
   initialization and settings
-    should emit SETTINGS on new connection
+    should return odd stream IDs
     should initialize client with custom connection settings
-    should return even stream IDs
+    should initialize client when receiving server settings before sending ack
+    should emit connection header and SETTINGS on new client connection
+  push
+    should auto RST_STREAM promises against locally-RST stream
+    should raise error on PUSH_PROMISE against stream 0
+    should raise error on PUSH_PROMISE against non-idle stream
+    should emit stream object for received PUSH_PROMISE
+    should disallow client initiated push
+    should emit promise headers for received PUSH_PROMISE
+    should raise error on PUSH_PROMISE against bogus stream
+  alt-svc
+    received in the connection
+      should not emit :altsvc when the frame when contains no host
+      should emit :altsvc when receiving one
+    received in a stream
+      should emit :altsvc
+      should not emit :alt_svc when the frame when contains a origin
+
+HTTP2::Emitter
+  should execute callback exactly once
+  should raise error on missing callback
+  should execute callback with optional args
+  should allow multiple callbacks on single event
+  should allow events with no callbacks
+  should pass emitted callbacks to listeners
 
 HTTP2::Header
   header representation
@@ -1123,517 +1213,497 @@
       should handle literal header
       should handle indexed header
     literal w/o indexing representation
-      should handle literal header
       should handle indexed header
+      should handle literal header
     literal w/ incremental indexing
       should handle indexed header
       should handle literal header
-  encode
-    spec example D.6.  Response Examples with Huffman
-      request 3
-        should compute header table size
-88c16196d07abe941054d444a8200595040b8166e084a62d1bffc05a839bd9ab77ad94e7821dd7f2e6c7b335dfdfcd5b3960d5af27087f3672c1ab270fb5291f9587316065c003ed4ee5b1063d5007
-        should emit expected bytes on wire
+  decode
+    spec example D.4.b.  Request Examples with Huffman - Server Handling of Improperly Ordered Headers
+      request 1
+        should raise CompressionError
+    spec example D.6.a.  Response Examples with Huffman - dynamic table size updates should not trigger exceptions
+      request 1
+        should emit expected headers
         should update header table
+        should compute header table size
+    spec example D.6.  Response Examples with Huffman
       request 2
-4883640effc1c0bf
-        should emit expected bytes on wire
         should update header table
         should compute header table size
+        should emit expected headers
       request 1
-        should update header table
         should compute header table size
-488264025885aec3771a4b6196d07abe941054d444a8200595040b8166e082a62d1bff6e919d29ad171863c78f0b97c8e9ae82ae43d3
-        should emit expected bytes on wire
-    spec example D.4.  Request Examples with Huffman
+        should update header table
+        should emit expected headers
       request 3
+        should emit expected headers
         should compute header table size
         should update header table
-828785bf408825a849e95ba97d7f8925a849e95bb8e8b4bf
-        should emit expected bytes on wire
+    spec example D.5.  Response Examples without Huffman
+      request 3
+        should update header table
+        should emit expected headers
+        should compute header table size
       request 2
         should compute header table size
+        should emit expected headers
         should update header table
-828684be5886a8eb10649cbf
-        should emit expected bytes on wire
       request 1
-        should update header table
-828684418cf1e3c2e5f23a6ba0ab90f4ff
-        should emit expected bytes on wire
         should compute header table size
-    spec example D.5.  Response Examples without Huffman
+        should emit expected headers
+        should update header table
+    spec example D.3. Request Examples without Huffman
       request 1
+        should emit expected headers
         should update header table
-4803333032580770726976617465611d4d6f6e2c203231204f637420323031332032303a31333a323120474d546e1768747470733a2f2f7777772e6578616d706c652e636f6d
-        should emit expected bytes on wire
-        should compute header table size
-      request 2
-4803333037c1c0bf
-        should emit expected bytes on wire
         should compute header table size
-        should update header table
       request 3
         should update header table
-88c1611d4d6f6e2c203231204f637420323031332032303a31333a323220474d54c05a04677a69707738666f6f3d4153444a4b48514b425a584f5157454f50495541585157454f49553b206d61782d6167653d333630303b2076657273696f6e3d31
-        should emit expected bytes on wire
         should compute header table size
-    spec example D.4.a.  Request Examples with Huffman - Client Handling of Improperly Ordered Headers
+        should emit expected headers
+      request 2
+        should emit expected headers
+        should compute header table size
+        should update header table
+    spec example D.4.  Request Examples with Huffman
       request 1
         should update header table
-828684418cf1e3c2e5f23a6ba0ab90f4ff
-        should emit expected bytes on wire
+        should emit expected headers
         should compute header table size
       request 3
         should compute header table size
-828785bf408825a849e95ba97d7f8925a849e95bb8e8b4bf
-        should emit expected bytes on wire
-        should update header table
-      request 2
         should update header table
-        should compute header table size
-828684be5886a8eb10649cbf
-        should emit expected bytes on wire
-    spec example D.3. Request Examples without Huffman
+        should emit expected headers
       request 2
         should compute header table size
-828684be58086e6f2d6361636865
-        should emit expected bytes on wire
         should update header table
+        should emit expected headers
+    spec example D.4.a.  Request Examples with Huffman - Client Handling of Improperly Ordered Headers
+      request 3
+        should emit expected headers
+        should update header table
+        should compute header table size
       request 1
-828684410f7777772e6578616d706c652e636f6d
-        should emit expected bytes on wire
         should compute header table size
         should update header table
-      request 3
+        should emit expected headers
+      request 2
         should update header table
+        should emit expected headers
         should compute header table size
-828785bf400a637573746f6d2d6b65790c637573746f6d2d76616c7565
-        should emit expected bytes on wire
   literal representation
     string
-      should handle long utf-8 strings with huffman
-      should handle utf-8 codepoints with huffman
-      should handle ascii codepoints with huffman
       should handle ascii codepoints without huffman
+      should handle utf-8 codepoints with huffman
       should handle utf-8 codepoints without huffman
+      should handle long utf-8 strings with huffman
       should handle long utf-8 strings without huffman
+      should handle ascii codepoints with huffman
       choosing shorter representation
+        should return huffman representation
         should return plain representation
         should return plain representation
-        should return huffman representation
     integer
+      should encode 10 using a 5-bit prefix
+      should encode 10 using a 0-bit prefix
       should encode 1337 using a 5-bit prefix
       should encode 1337 using a 0-bit prefix
-      should encode 10 using a 0-bit prefix
-      should encode 10 using a 5-bit prefix
-  decode
-    spec example D.5.  Response Examples without Huffman
-      request 2
-        should compute header table size
-        should emit expected headers
-        should update header table
+  encode
+    spec example D.6.  Response Examples with Huffman
       request 3
-        should emit expected headers
+88c16196d07abe941054d444a8200595040b8166e084a62d1bffc05a839bd9ab77ad94e7821dd7f2e6c7b335dfdfcd5b3960d5af27087f3672c1ab270fb5291f9587316065c003ed4ee5b1063d5007
+        should emit expected bytes on wire
+        should update header table
         should compute header table size
+      request 2
+4883640effc1c0bf
+        should emit expected bytes on wire
         should update header table
+        should compute header table size
       request 1
-        should emit expected headers
+488264025885aec3771a4b6196d07abe941054d444a8200595040b8166e082a62d1bff6e919d29ad171863c78f0b97c8e9ae82ae43d3
+        should emit expected bytes on wire
         should update header table
         should compute header table size
     spec example D.4.  Request Examples with Huffman
       request 2
-        should emit expected headers
-        should update header table
         should compute header table size
-      request 3
-        should emit expected headers
+828684be5886a8eb10649cbf
+        should emit expected bytes on wire
         should update header table
-        should compute header table size
       request 1
+828684418cf1e3c2e5f23a6ba0ab90f4ff
+        should emit expected bytes on wire
         should compute header table size
-        should emit expected headers
         should update header table
-    spec example D.4.a.  Request Examples with Huffman - Client Handling of Improperly Ordered Headers
-      request 1
+      request 3
+828785bf408825a849e95ba97d7f8925a849e95bb8e8b4bf
+        should emit expected bytes on wire
         should update header table
-        should emit expected headers
         should compute header table size
+    spec example D.5.  Response Examples without Huffman
+      request 3
+88c1611d4d6f6e2c203231204f637420323031332032303a31333a323220474d54c05a04677a69707738666f6f3d4153444a4b48514b425a584f5157454f50495541585157454f49553b206d61782d6167653d333630303b2076657273696f6e3d31
+        should emit expected bytes on wire
+        should compute header table size
+        should update header table
       request 2
         should update header table
-        should emit expected headers
+4803333037c1c0bf
+        should emit expected bytes on wire
         should compute header table size
-      request 3
-        should emit expected headers
+      request 1
+        should compute header table size
+        should update header table
+4803333032580770726976617465611d4d6f6e2c203231204f637420323031332032303a31333a323120474d546e1768747470733a2f2f7777772e6578616d706c652e636f6d
+        should emit expected bytes on wire
+    spec example D.3. Request Examples without Huffman
+      request 1
         should update header table
+828684410f7777772e6578616d706c652e636f6d
+        should emit expected bytes on wire
         should compute header table size
-    spec example D.6.  Response Examples with Huffman
       request 3
         should update header table
-        should emit expected headers
+828785bf400a637573746f6d2d6b65790c637573746f6d2d76616c7565
+        should emit expected bytes on wire
         should compute header table size
       request 2
-        should compute header table size
         should update header table
-        should emit expected headers
-      request 1
-        should emit expected headers
         should compute header table size
-        should update header table
-    spec example D.4.b.  Request Examples with Huffman - Server Handling of Improperly Ordered Headers
-      request 1
-        should raise CompressionError
-    spec example D.3. Request Examples without Huffman
+828684be58086e6f2d6361636865
+        should emit expected bytes on wire
+    spec example D.4.a.  Request Examples with Huffman - Client Handling of Improperly Ordered Headers
       request 2
-        should emit expected headers
         should compute header table size
+828684be5886a8eb10649cbf
+        should emit expected bytes on wire
         should update header table
       request 3
-        should update header table
-        should emit expected headers
         should compute header table size
-      request 1
+828785bf408825a849e95ba97d7f8925a849e95bb8e8b4bf
+        should emit expected bytes on wire
         should update header table
-        should compute header table size
-        should emit expected headers
-    spec example D.6.a.  Response Examples with Huffman - dynamic table size updates should not trigger exceptions
       request 1
-        should compute header table size
-        should emit expected headers
+828684418cf1e3c2e5f23a6ba0ab90f4ff
+        should emit expected bytes on wire
         should update header table
+        should compute header table size
   shared compression context
     should be initialized with empty headers
     encode
       downcases the field
       fills :path if empty
     processing
-      should clear table if entry exceeds table size
-      should reject table size update if exceed limit
       should shrink table if set smaller size
+      should reject table size update if exceed limit
+      should clear table if entry exceeds table size
       never indexed
         should process literal header with literal value
         should process indexed header with literal value
-      size bounds
-        should drop headers from end of table
       no indexing
-        should process indexed header with literal value
         should process literal header with literal value
-      incremental indexing
         should process indexed header with literal value
+      incremental indexing
         should process literal header with literal value
+        should process indexed header with literal value
+      size bounds
+        should drop headers from end of table
+
+HTTP2::Header::Huffman
+  decode
+    should encode then decode 'UTF-8でエンコードした日本語文字列' into the same
+    should decode f1e3c2e5f23a6ba0ab90f4ff into www.example.com
+    should encode then decode 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8' into the same
+    should raise when input is shorter than expected
+    should encode then decode 'http://www.craigslist.org/about/sites/' into the same
+    should encode then decode 'cl_b=AB2BKbsl4hGM7M4nH5PYWghTM5A; cl_def_lang=en; cl_def_hp=shoals' into the same
+    should raise when input is not padded by 1s
+    should encode then decode 'BX=c99r6jp89a7no&b=3&s=q4; localization=en-us%3Bus%3Bus' into the same
+    should raise when EOS is explicitly encoded
+    should decode d07abe941054d444a8200595040b8166e082a62d1bff into Mon, 21 Oct 2013 20:13:21 GMT
+    should decode a8eb10649cbf into no-cache
+    should raise when exceedingly padded
+    should encode then decode 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:16.0) Gecko/20100101 Firefox/16.0' into the same
+    should encode then decode 'image/png,image/*;q=0.8,*/*;q=0.5' into the same
+    should encode/decode all_possible 2-byte sequences
+  encode
+    should encode Mon, 21 Oct 2013 20:13:21 GMT into d07abe941054d444a8200595040b8166e082a62d1bff
+    should encode www.example.com into f1e3c2e5f23a6ba0ab90f4ff
+    should encode no-cache into a8eb10649cbf
 
 HTTP2::Connection
-  framing
-    should decompress header blocks regardless of stream state
-    should generate CONTINUATION if HEADERS is too long
-    should emit encoded frames via on(:frame)
-    should compress stream headers
-    should raise connection error on decode of invalid frame
-    should require that split header blocks are a contiguous sequence
-    should not generate CONTINUATION if HEADERS fits exactly in a frame
-    should raise compression error on encode of invalid frame
-    should decode non-contiguous header blocks
-    should generate CONTINUATION if HEADERS exceed the max payload by one byte
-    should buffer incomplete frames
-    should not generate CONTINUATION if HEADERS fits exactly in a frame
   initialization and settings
-    should raise error if SETTINGS stream != 0
     should raise error if first frame is not settings
+    should raise error if SETTINGS stream != 0
     should not raise error if first frame is SETTINGS
-  settings synchronization
-    should send SETTINGS ACK when SETTINGS is received
-    should reflect outgoing settings when ack is received
-    should reflect incoming settings when SETTINGS is received
-  API
-    .window_update should emit WINDOW_UPDATE frames
-    .ping should generate PING frames
-    .settings should emit SETTINGS frames
-    .goaway should generate GOAWAY frame with last processed stream ID
-  stream management
-    should count open streams against stream limit
-    should initialize to default stream limit (100)
-    should change stream limit to received SETTINGS value
-    should not count reserved streams against stream limit
-    should not exceed stream limit set by peer
-    should initialize stream with HEADERS priority value
-    should initialize idle stream on PRIORITY frame
   flow control
-    should initialize streams with window specified by peer
-    should update window when data received is over half of the maximum local window size
     should observe connection flow control
+    should update window when data received is over half of the maximum local window size
     should initialize to default flow window
     should update connection and stream windows on SETTINGS
+    should initialize streams with window specified by peer
   connection management
-    should raise error on frame for invalid stream ID
-    should process connection management frames after GOAWAY
+    should not raise error when receiving connection management frames immediately after emitting goaway
     should send GOAWAY frame on connection error
-    should raise error on invalid connection header
     should not raise an error on frame for a closed stream ID
     should respond to PING frames
+    should process connection management frames after GOAWAY
+    should raise error on frame for invalid stream ID
     should raise error when opening new stream after receiving GOAWAY
-    should not raise error when receiving connection management frames immediately after emitting goaway
+    should fire callback on PONG
     should fire callback on receipt of GOAWAY
     should raise error when opening new stream after sending GOAWAY
-    should fire callback on PONG
+    should raise error on invalid connection header
+  framing
+    should buffer incomplete frames
+    should require that split header blocks are a contiguous sequence
+    should not generate CONTINUATION if HEADERS fits exactly in a frame
+    should not generate CONTINUATION if HEADERS fits exactly in a frame
+    should generate CONTINUATION if HEADERS is too long
+    should compress stream headers
+    should raise connection error on decode of invalid frame
+    should emit encoded frames via on(:frame)
+    should raise compression error on encode of invalid frame
+    should decompress header blocks regardless of stream state
+    should generate CONTINUATION if HEADERS exceed the max payload by one byte
+    should decode non-contiguous header blocks
   Headers pre/post processing
     should not concatenate multiple occurences of a header field with the same name
     should not split zero-concatenated header field values
+  API
+    .ping should generate PING frames
+    .settings should emit SETTINGS frames
+    .window_update should emit WINDOW_UPDATE frames
+    .goaway should generate GOAWAY frame with last processed stream ID
+  settings synchronization
+    should send SETTINGS ACK when SETTINGS is received
+    should reflect outgoing settings when ack is received
+    should reflect incoming settings when SETTINGS is received
   cleanup_recently_closed
     should cleanup old connections
-
-HTTP2::Client
-  alt-svc
-    received in the connection
-      should not emit :altsvc when the frame when contains no host
-      should emit :altsvc when receiving one
-    received in a stream
-      should not emit :alt_svc when the frame when contains a origin
-      should emit :altsvc
-  upgrade
-    fails when client has already created streams
-    sends the preface
-    initializes the first stream in the half-closed state
-  initialization and settings
-    should initialize client with custom connection settings
-    should initialize client when receiving server settings before sending ack
-    should emit connection header and SETTINGS on new client connection
-    should return odd stream IDs
-  push
-    should raise error on PUSH_PROMISE against stream 0
-    should emit stream object for received PUSH_PROMISE
-    should auto RST_STREAM promises against locally-RST stream
-    should raise error on PUSH_PROMISE against bogus stream
-    should disallow client initiated push
-    should emit promise headers for received PUSH_PROMISE
-    should raise error on PUSH_PROMISE against non-idle stream
-
-HTTP2::Emitter
-  should execute callback exactly once
-  should allow events with no callbacks
-  should allow multiple callbacks on single event
-  should pass emitted callbacks to listeners
-  should execute callback with optional args
-  should raise error on missing callback
+  stream management
+    should initialize to default stream limit (100)
+    should not count reserved streams against stream limit
+    should count open streams against stream limit
+    should change stream limit to received SETTINGS value
+    should initialize stream with HEADERS priority value
+    should not exceed stream limit set by peer
+    should initialize idle stream on PRIORITY frame
 
 HTTP2::Stream
   server API
     should emit received priority parameters via on(:priority)
-    should emit received payload via on(:data)
     should emit received headers via on(:headers)
+    should emit received payload via on(:data)
     push
       .promise push stream should have parent stream
       .promise should emit server initiated stream
       stream states
-        client: promise_headers > active > headers > .. > data > close
         server: active > half close > close
+        client: promise_headers > active > headers > .. > data > close
   flow control
     should update window size on DATA frames only
-    should observe session flow control
-    should update window when data received is over half of the maximum local window size
     should not update window when data received is less than half of maximum local window size
-    should update window size on receipt of WINDOW_UPDATE
+    should update window when data received is over half of the maximum local window size
     should initialize to default flow control window
+    should observe session flow control
+    should update window size on receipt of WINDOW_UPDATE
   client API
-    .refuse should reset stream with refused stream error code
-    .data should split large multibyte DATA frames
     .cancel should reset stream with cancel error code
-    .window_update should emit WINDOW_UPDATE frames
-    .reprioritize should raise error if invoked by server
     .headers should emit HEADERS frames
+    .reprioritize should raise error if invoked by server
     .data should split large DATA frames
     .reprioritize should emit PRIORITY frame
+    .window_update should emit WINDOW_UPDATE frames
+    .data should split large multibyte DATA frames
     .data should emit DATA frames
+    .refuse should reset stream with refused stream error code
   stream states
     should initiliaze all streams to IDLE
     should set custom stream priority
+    closed
+      local closed via RST_STREAM frame
+        should ignore received frames
+      remote closed stream
+        should ignore received WINDOW_UPDATE frames
+        should allow PRIORITY, RST_STREAM to be received
+        should raise STREAM_CLOSED on receipt of frame
+        should raise STREAM_CLOSED on attempt to send frames
+        should allow PRIORITY, RST_STREAM to be sent
+        should reprioritize stream on received PRIORITY
+        should reprioritize stream on sent PRIORITY
+    reserved (local)
+      should raise error if sending invalid frames
+      should transition to half closed (remote) on sent HEADERS
+      should transition to closed on sent RST_STREAM
+      should allow HEADERS to be sent
+      should increment remote_window on received WINDOW_UPDATE
+      should reprioritize stream on PRIORITY
+      should raise error on receipt of invalid frames
+      should transition on sent PUSH_PROMISE
+      should transition to closed on received RST_STREAM
     half closed (remote)
-      should reprioritize stream on received PRIORITY
+      should emit :half_close event on transition
       should ignore sent WINDOW_UPDATE frames
-      should emit :close event on close transition
       should transition to closed if END_STREAM flag is sent
-      should increment remote_window on received WINDOW_UPDATE
+      should raise STREAM_CLOSED error on reciept of frames
+      should reprioritize stream on received PRIORITY
       should not transition to closed if END_STREAM flag is sent when overflowing window
+      should transition to closed if RST_STREAM is sent
+      should emit :close event on close transition
       should transition to closed when send buffer is emptied
       should transition to closed on reciept of RST_STREAM frame
-      should emit :half_close event on transition
-      should transition to closed if RST_STREAM is sent
-      should raise STREAM_CLOSED error on reciept of frames
+      should increment remote_window on received WINDOW_UPDATE
       should reprioritize stream on sent PRIORITY
-    reserved (local)
-      should transition to closed on received RST_STREAM
-      should allow HEADERS to be sent
-      should raise error if sending invalid frames
-      should transition to half closed (remote) on sent HEADERS
+    reserved (remote)
       should reprioritize stream on PRIORITY
-      should raise error on receipt of invalid frames
-      should increment remote_window on received WINDOW_UPDATE
+      should increment local_window on sent WINDOW_UPDATE
+      should transition on received PUSH_PROMISE
       should transition to closed on sent RST_STREAM
-      should transition on sent PUSH_PROMISE
+      should raise error on receipt of invalid frames
+      should raise error if sending invalid frames
+      should transition to closed on received RST_STREAM
+      should transition to half closed (local) on received HEADERS
+    open
+      should allow any valid frames types to be sent
+      should emit :close with reason
+      should reprioritize stream on received PRIORITY
+      should emit :active on open transition
+      should transition to half closed if local opened with END_STREAM
+      should emit :close after frame is processed
+      should transition to half closed (remote) if receiving END_STREAM
+      should transition to closed if sending RST_STREAM
+      should not emit :active on transition from open
+      should transition to closed if receiving RST_STREAM
+      should transition to half closed (local) if sending END_STREAM
+      should reprioritize stream on sent PRIORITY
+      should transition to half closed if remote opened with END_STREAM
+      should emit :close on close transition
+      should allow frames of any type to be received
     half closed (local)
       should raise error on attempt to send invalid frames
-      should ignore received PRIORITY frames
-      should transition to closed on receipt of RST_STREAM frame
-      should emit :half_close event on transition
-      should transition to closed if RST_STREAM frame is sent
-      should increment local_window on sent WINDOW_UPDATE
-      should reprioritize stream on sent PRIORITY
       should ignore received WINDOW_UPDATE frames
+      should emit :half_close event on transition
+      should transition to closed on receipt of RST_STREAM frame
       should reprioritize stream (and decendants) on received PRIORITY
       should emit :close event on transition to closed
-      should transition to closed on receipt of END_STREAM flag
-    closed
-      local closed via RST_STREAM frame
-        should ignore received frames
-      remote closed stream
-        should raise STREAM_CLOSED on receipt of frame
-        should reprioritize stream on received PRIORITY
-        should raise STREAM_CLOSED on attempt to send frames
-        should allow PRIORITY, RST_STREAM to be sent
-        should allow PRIORITY, RST_STREAM to be received
-        should reprioritize stream on sent PRIORITY
-        should ignore received WINDOW_UPDATE frames
-    reserved (remote)
-      should transition on received PUSH_PROMISE
-      should transition to half closed (local) on received HEADERS
+      should reprioritize stream on sent PRIORITY
+      should transition to closed if RST_STREAM frame is sent
+      should ignore received PRIORITY frames
       should increment local_window on sent WINDOW_UPDATE
-      should transition to closed on received RST_STREAM
-      should transition to closed on sent RST_STREAM
-      should raise error on receipt of invalid frames
-      should raise error if sending invalid frames
-      should reprioritize stream on PRIORITY
+      should transition to closed on receipt of END_STREAM flag
     idle
-      should reprioritize stream on sent PRIORITY
-      should transition to open on received HEADERS
       should transition to reserved (remote) on received PUSH_PROMISE
-      should transition to open on sent HEADERS
       should reprioritize stream on received PRIORITY
+      should transition to open on received HEADERS
+      should transition to open on sent HEADERS
       should transition to reserved (local) on sent PUSH_PROMISE
-    open
-      should transition to half closed (local) if sending END_STREAM
-      should not emit :active on transition from open
-      should emit :close after frame is processed
-      should transition to half closed (remote) if receiving END_STREAM
-      should allow frames of any type to be received
-      should emit :close on close transition
       should reprioritize stream on sent PRIORITY
-      should emit :close with reason
-      should allow any valid frames types to be sent
-      should emit :active on open transition
-      should transition to closed if receiving RST_STREAM
-      should transition to closed if sending RST_STREAM
-      should transition to half closed if remote opened with END_STREAM
-      should transition to half closed if local opened with END_STREAM
-      should reprioritize stream on received PRIORITY
+
+HTTP2::Server
+  should allow server push
+  initialization and settings
+    should initialize client with custom connection settings
+    should return even stream IDs
+    should emit SETTINGS on new connection
+
+HTTP2::Buffer
+  should force 8-bit encoding when adding data
+  should force 8-bit encoding
+  should read single byte at a time
+  should return bytesize of the buffer
+  should unpack an unsigned 32-bit int
 
 HTTP2::Framer
-  should parse single frame at a time
   should ignore unknown extension frames
-  should determine frame length
   should process full frames only
-  WINDOW_UPDATE
-    should generate and parse bytes
-  PING
-    should raise exception on invalid payload
-    should generate and parse bytes
-  common header
-    should raise exception on invalid frame size
-    should generate common 9 byte header
-    should raise exception on invalid frame type when sending
-    should generate a large frame
-    should parse common 9 byte header
-    should raise exception on invalid stream ID
-    should raise exception on invalid frame flag
-  PRIORITY
-    should generate and parse bytes
-  ALTSVC
-    should generate and parse bytes
-  SETTINGS
-    should raise exception on receiving invalid payload length
-    should raise exception on receiving invalid stream ID
-    should ignore custom settings when receiving
-    should ignore custom settings when sending
-    should raise exception on sending invalid setting
+  should determine frame length
+  should parse single frame at a time
+  DATA
     should generate and parse bytes
-    should generate settings when id is given as an integer
-    should raise exception on sending invalid stream ID
   CONTINUATION
     should generate and parse bytes
-  GOAWAY
-    should treat debug payload as optional
-    should generate and parse bytes
-  RST_STREAM
-    should generate and parse bytes
-  PUSH_PROMISE
+  PING
     should generate and parse bytes
-  HEADERS
-    should carry an optional stream priority
+    should raise exception on invalid payload
+  ALTSVC
     should generate and parse bytes
   Padding
-    generating headers frame padded 1
+    generating push_promise frame padded 256
       should parse a frame with padding
-      should fill padded octets with zero
       should preserve payload
+      should fill padded octets with zero
       should generate a frame with padding
-    generating push_promise frame padded 1
-      should parse a frame with padding
-      should generate a frame with padding
+    generating data frame padded 1
       should fill padded octets with zero
+      should generate a frame with padding
       should preserve payload
-    generating headers frame padded 256
       should parse a frame with padding
+    generating headers frame padded 256
+      should generate a frame with padding
       should fill padded octets with zero
+      should parse a frame with padding
+      should preserve payload
+    generating headers frame padded 1
       should generate a frame with padding
       should preserve payload
-    generating push_promise frame padded 256
       should parse a frame with padding
       should fill padded octets with zero
-      should preserve payload
+    generating push_promise frame padded 1
       should generate a frame with padding
+      should fill padded octets with zero
+      should parse a frame with padding
+      should preserve payload
     generating with invalid padding length
       should raise error when adding a padding would make frame too large
-      should raise error on trying to generate data frame padded with invalid 0
       should raise error on trying to generate data frame padded with invalid 257
+      should raise error on trying to generate data frame padded with invalid 0
       should raise error on trying to generate data frame padded with invalid 1334
+    parsing frames with invalid paddings
+      should raise exception when the given padding is longer than the payload
     generating data frame padded 256
-      should generate a frame with padding
-      should fill padded octets with zero
-      should preserve payload
-      should parse a frame with padding
-    generating data frame padded 1
-      should fill padded octets with zero
       should parse a frame with padding
       should generate a frame with padding
+      should fill padded octets with zero
       should preserve payload
-    parsing frames with invalid paddings
-      should raise exception when the given padding is longer than the payload
-  DATA
+  PUSH_PROMISE
+    should generate and parse bytes
+  PRIORITY
+    should generate and parse bytes
+  SETTINGS
+    should raise exception on receiving invalid stream ID
+    should raise exception on sending invalid stream ID
+    should ignore custom settings when receiving
+    should generate settings when id is given as an integer
+    should raise exception on sending invalid setting
+    should raise exception on receiving invalid payload length
+    should ignore custom settings when sending
+    should generate and parse bytes
+  WINDOW_UPDATE
+    should generate and parse bytes
+  HEADERS
+    should generate and parse bytes
+    should carry an optional stream priority
+  common header
+    should raise exception on invalid frame size
+    should generate a large frame
+    should raise exception on invalid frame flag
+    should generate common 9 byte header
+    should parse common 9 byte header
+    should raise exception on invalid stream ID
+    should raise exception on invalid frame type when sending
+  GOAWAY
+    should generate and parse bytes
+    should treat debug payload as optional
+  RST_STREAM
     should generate and parse bytes
 
-HTTP2::Header::Huffman
-  decode
-    should encode then decode 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:16.0) Gecko/20100101 Firefox/16.0' into the same
-    should encode then decode 'BX=c99r6jp89a7no&b=3&s=q4; localization=en-us%3Bus%3Bus' into the same
-    should raise when exceedingly padded
-    should encode then decode 'cl_b=AB2BKbsl4hGM7M4nH5PYWghTM5A; cl_def_lang=en; cl_def_hp=shoals' into the same
-    should decode f1e3c2e5f23a6ba0ab90f4ff into www.example.com
-    should encode/decode all_possible 2-byte sequences
-    should encode then decode 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8' into the same
-    should encode then decode 'http://www.craigslist.org/about/sites/' into the same
-    should decode a8eb10649cbf into no-cache
-    should raise when input is shorter than expected
-    should decode d07abe941054d444a8200595040b8166e082a62d1bff into Mon, 21 Oct 2013 20:13:21 GMT
-    should raise when input is not padded by 1s
-    should raise when EOS is explicitly encoded
-    should encode then decode 'image/png,image/*;q=0.8,*/*;q=0.5' into the same
-    should encode then decode 'UTF-8でエンコードした日本語文字列' into the same
-  encode
-    should encode no-cache into a8eb10649cbf
-    should encode Mon, 21 Oct 2013 20:13:21 GMT into d07abe941054d444a8200595040b8166e082a62d1bff
-    should encode www.example.com into f1e3c2e5f23a6ba0ab90f4ff
-
-Finished in 1.17 seconds (files took 0.28542 seconds to load)
+Finished in 2.21 seconds (files took 0.50312 seconds to load)
 381 examples, 0 failures
 
-Randomized with seed 17860
+Randomized with seed 55665
 
 
 ┌──────────────────────────────────────────────────────────────────────────────┐
@@ -1663,12 +1733,14 @@
  dpkg-source --after-build .
 dpkg-buildpackage: info: binary-only upload (no source included)
 I: copying local configuration
+I: user script /srv/workspace/pbuilder/5076/tmp/hooks/B01_cleanup starting
+I: user script /srv/workspace/pbuilder/5076/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/13054 and its subdirectories
-I: Current time: Sun Jul 10 09:31:48 -12 2022
-I: pbuilder-time-stamp: 1657488708
+I: removing directory /srv/workspace/pbuilder/5076 and its subdirectories
+I: Current time: Tue Jun  8 05:13:22 +14 2021
+I: pbuilder-time-stamp: 1623078802