Diff of the two buildlogs: -- --- b1/build.log 2021-08-24 00:52:24.144069630 +0000 +++ b2/build.log 2021-08-24 01:01:59.138556204 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Mon Aug 23 12:47:52 -12 2021 -I: pbuilder-time-stamp: 1629766072 +I: Current time: Tue Aug 24 14:52:45 +14 2021 +I: pbuilder-time-stamp: 1629766365 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/bullseye-reproducible-base.tgz] I: copying local configuration @@ -16,8 +16,8 @@ I: copying [./ruby-httparty_0.18.1-2.debian.tar.xz] I: Extracting source gpgv: unknown type of key resource 'trustedkeys.kbx' -gpgv: keyblock resource '/tmp/dpkg-verify-sig.7jpFkNpM/trustedkeys.kbx': General error -gpgv: Signature made Tue Nov 17 00:22:57 2020 -12 +gpgv: keyblock resource '/tmp/dpkg-verify-sig.KzXl8lTg/trustedkeys.kbx': General error +gpgv: Signature made Wed Nov 18 02:22:57 2020 +14 gpgv: using RSA key 9CCD6B319DBF8E40AB1ABD1A89AF82B739CD217A gpgv: Can't check signature: No public key dpkg-source: warning: failed to verify signature on ./ruby-httparty_0.18.1-2.dsc @@ -31,135 +31,169 @@ dpkg-source: info: applying no_pry_in_specs.patch I: Not using root during the build. I: Installing the build-deps -I: user script /srv/workspace/pbuilder/12788/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/23481/tmp/hooks/D01_modify_environment starting +debug: Running on cbxi4b. +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/23481/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/23481/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,-fixfilepath parallel=3' - DISTRIBUTION='' - HOME='/root' - HOST_ARCH='armhf' + 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]="arm-unknown-linux-gnueabihf") + 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=armhf + DEBIAN_FRONTEND=noninteractive + DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all,-fixfilepath parallel=4' + DIRSTACK=() + DISTRIBUTION= + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=arm + HOST_ARCH=armhf IFS=' ' - INVOCATION_ID='699327c2d3b04ac98a2ad6c177c08b96' - 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='12788' - PS1='# ' - PS2='> ' + INVOCATION_ID=ef8abb308cdb4aa28cb06f451836414a + 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=23481 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.k6dWCqzj9J/pbuilderrc_IIra --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/bullseye-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/tmp.k6dWCqzj9J/b1 --logfile b1/build.log ruby-httparty_0.18.1-2.dsc' - SUDO_GID='114' - SUDO_UID='108' - 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:8000/' + 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.k6dWCqzj9J/pbuilderrc_CJQU --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/bullseye-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/tmp.k6dWCqzj9J/b2 --logfile b2/build.log ruby-httparty_0.18.1-2.dsc' + SUDO_GID=116 + SUDO_UID=112 + 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:8000/ I: uname -a - Linux jtx1a 5.10.0-8-arm64 #1 SMP Debian 5.10.46-4 (2021-08-03) aarch64 GNU/Linux + Linux i-capture-the-hostname 5.10.0-8-armmp #1 SMP Debian 5.10.46-4 (2021-08-03) armv7l GNU/Linux I: ls -l /bin total 3580 - -rwxr-xr-x 1 root root 816764 Aug 4 08:25 bash - -rwxr-xr-x 3 root root 26052 Jul 20 2020 bunzip2 - -rwxr-xr-x 3 root root 26052 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 26052 Jul 20 2020 bzip2 - -rwxr-xr-x 1 root root 9636 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 26668 Sep 22 2020 cat - -rwxr-xr-x 1 root root 43104 Sep 22 2020 chgrp - -rwxr-xr-x 1 root root 38984 Sep 22 2020 chmod - -rwxr-xr-x 1 root root 43112 Sep 22 2020 chown - -rwxr-xr-x 1 root root 92616 Sep 22 2020 cp - -rwxr-xr-x 1 root root 75524 Dec 10 2020 dash - -rwxr-xr-x 1 root root 75880 Sep 22 2020 date - -rwxr-xr-x 1 root root 55436 Sep 22 2020 dd - -rwxr-xr-x 1 root root 59912 Sep 22 2020 df - -rwxr-xr-x 1 root root 96764 Sep 22 2020 dir - -rwxr-xr-x 1 root root 55012 Jul 28 07:09 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 22508 Sep 22 2020 echo - -rwxr-xr-x 1 root root 28 Nov 9 2020 egrep - -rwxr-xr-x 1 root root 22496 Sep 22 2020 false - -rwxr-xr-x 1 root root 28 Nov 9 2020 fgrep - -rwxr-xr-x 1 root root 47492 Jul 28 07:09 findmnt - -rwsr-xr-x 1 root root 26076 Feb 26 04:12 fusermount - -rwxr-xr-x 1 root root 124508 Nov 9 2020 grep - -rwxr-xr-x 2 root root 2346 Mar 2 11:30 gunzip - -rwxr-xr-x 1 root root 6376 Mar 2 11:30 gzexe - -rwxr-xr-x 1 root root 64212 Mar 2 11:30 gzip - -rwxr-xr-x 1 root root 13784 Nov 6 2019 hostname - -rwxr-xr-x 1 root root 43180 Sep 22 2020 ln - -rwxr-xr-x 1 root root 35068 Feb 7 2020 login - -rwxr-xr-x 1 root root 96764 Sep 22 2020 ls - -rwxr-xr-x 1 root root 99940 Jul 28 07:09 lsblk - -rwxr-xr-x 1 root root 51408 Sep 22 2020 mkdir - -rwxr-xr-x 1 root root 43184 Sep 22 2020 mknod - -rwxr-xr-x 1 root root 30780 Sep 22 2020 mktemp - -rwxr-xr-x 1 root root 34408 Jul 28 07:09 more - -rwsr-xr-x 1 root root 34400 Jul 28 07:09 mount - -rwxr-xr-x 1 root root 9824 Jul 28 07:09 mountpoint - -rwxr-xr-x 1 root root 88524 Sep 22 2020 mv - lrwxrwxrwx 1 root root 8 Nov 6 2019 nisdomainname -> hostname - lrwxrwxrwx 1 root root 14 Apr 18 03:38 pidof -> /sbin/killall5 - -rwxr-xr-x 1 root root 26652 Sep 22 2020 pwd - lrwxrwxrwx 1 root root 4 Aug 4 08:25 rbash -> bash - -rwxr-xr-x 1 root root 30740 Sep 22 2020 readlink - -rwxr-xr-x 1 root root 43104 Sep 22 2020 rm - -rwxr-xr-x 1 root root 30732 Sep 22 2020 rmdir - -rwxr-xr-x 1 root root 14144 Sep 27 2020 run-parts - -rwxr-xr-x 1 root root 76012 Dec 22 2018 sed - lrwxrwxrwx 1 root root 4 Aug 20 21:26 sh -> dash - -rwxr-xr-x 1 root root 22532 Sep 22 2020 sleep - -rwxr-xr-x 1 root root 55360 Sep 22 2020 stty - -rwsr-xr-x 1 root root 46704 Jul 28 07:09 su - -rwxr-xr-x 1 root root 22532 Sep 22 2020 sync - -rwxr-xr-x 1 root root 340872 Feb 16 2021 tar - -rwxr-xr-x 1 root root 9808 Sep 27 2020 tempfile - -rwxr-xr-x 1 root root 67696 Sep 22 2020 touch - -rwxr-xr-x 1 root root 22496 Sep 22 2020 true - -rwxr-xr-x 1 root root 9636 Feb 26 04:12 ulockmgr_server - -rwsr-xr-x 1 root root 22108 Jul 28 07:09 umount - -rwxr-xr-x 1 root root 22520 Sep 22 2020 uname - -rwxr-xr-x 2 root root 2346 Mar 2 11:30 uncompress - -rwxr-xr-x 1 root root 96764 Sep 22 2020 vdir - -rwxr-xr-x 1 root root 38512 Jul 28 07:09 wdctl - lrwxrwxrwx 1 root root 8 Nov 6 2019 ypdomainname -> hostname - -rwxr-xr-x 1 root root 1984 Mar 2 11:30 zcat - -rwxr-xr-x 1 root root 1678 Mar 2 11:30 zcmp - -rwxr-xr-x 1 root root 5880 Mar 2 11:30 zdiff - -rwxr-xr-x 1 root root 29 Mar 2 11:30 zegrep - -rwxr-xr-x 1 root root 29 Mar 2 11:30 zfgrep - -rwxr-xr-x 1 root root 2081 Mar 2 11:30 zforce - -rwxr-xr-x 1 root root 7585 Mar 2 11:30 zgrep - -rwxr-xr-x 1 root root 2206 Mar 2 11:30 zless - -rwxr-xr-x 1 root root 1842 Mar 2 11:30 zmore - -rwxr-xr-x 1 root root 4553 Mar 2 11:30 znew -I: user script /srv/workspace/pbuilder/12788/tmp/hooks/D02_print_environment finished + -rwxr-xr-x 1 root root 816764 Aug 5 10:25 bash + -rwxr-xr-x 3 root root 26052 Jul 21 2020 bunzip2 + -rwxr-xr-x 3 root root 26052 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 26052 Jul 21 2020 bzip2 + -rwxr-xr-x 1 root root 9636 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 26668 Sep 23 2020 cat + -rwxr-xr-x 1 root root 43104 Sep 23 2020 chgrp + -rwxr-xr-x 1 root root 38984 Sep 23 2020 chmod + -rwxr-xr-x 1 root root 43112 Sep 23 2020 chown + -rwxr-xr-x 1 root root 92616 Sep 23 2020 cp + -rwxr-xr-x 1 root root 75524 Dec 11 2020 dash + -rwxr-xr-x 1 root root 75880 Sep 23 2020 date + -rwxr-xr-x 1 root root 55436 Sep 23 2020 dd + -rwxr-xr-x 1 root root 59912 Sep 23 2020 df + -rwxr-xr-x 1 root root 96764 Sep 23 2020 dir + -rwxr-xr-x 1 root root 55012 Jul 29 09:09 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 22508 Sep 23 2020 echo + -rwxr-xr-x 1 root root 28 Nov 10 2020 egrep + -rwxr-xr-x 1 root root 22496 Sep 23 2020 false + -rwxr-xr-x 1 root root 28 Nov 10 2020 fgrep + -rwxr-xr-x 1 root root 47492 Jul 29 09:09 findmnt + -rwsr-xr-x 1 root root 26076 Feb 27 06:12 fusermount + -rwxr-xr-x 1 root root 124508 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 64212 Mar 3 13:30 gzip + -rwxr-xr-x 1 root root 13784 Nov 8 2019 hostname + -rwxr-xr-x 1 root root 43180 Sep 23 2020 ln + -rwxr-xr-x 1 root root 35068 Feb 8 2020 login + -rwxr-xr-x 1 root root 96764 Sep 23 2020 ls + -rwxr-xr-x 1 root root 99940 Jul 29 09:09 lsblk + -rwxr-xr-x 1 root root 51408 Sep 23 2020 mkdir + -rwxr-xr-x 1 root root 43184 Sep 23 2020 mknod + -rwxr-xr-x 1 root root 30780 Sep 23 2020 mktemp + -rwxr-xr-x 1 root root 34408 Jul 29 09:09 more + -rwsr-xr-x 1 root root 34400 Jul 29 09:09 mount + -rwxr-xr-x 1 root root 9824 Jul 29 09:09 mountpoint + -rwxr-xr-x 1 root root 88524 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 26652 Sep 23 2020 pwd + lrwxrwxrwx 1 root root 4 Aug 5 10:25 rbash -> bash + -rwxr-xr-x 1 root root 30740 Sep 23 2020 readlink + -rwxr-xr-x 1 root root 43104 Sep 23 2020 rm + -rwxr-xr-x 1 root root 30732 Sep 23 2020 rmdir + -rwxr-xr-x 1 root root 14144 Sep 28 2020 run-parts + -rwxr-xr-x 1 root root 76012 Dec 23 2018 sed + lrwxrwxrwx 1 root root 4 Aug 24 14:54 sh -> bash + lrwxrwxrwx 1 root root 4 Aug 21 23:28 sh.distrib -> dash + -rwxr-xr-x 1 root root 22532 Sep 23 2020 sleep + -rwxr-xr-x 1 root root 55360 Sep 23 2020 stty + -rwsr-xr-x 1 root root 46704 Jul 29 09:09 su + -rwxr-xr-x 1 root root 22532 Sep 23 2020 sync + -rwxr-xr-x 1 root root 340872 Feb 17 2021 tar + -rwxr-xr-x 1 root root 9808 Sep 28 2020 tempfile + -rwxr-xr-x 1 root root 67696 Sep 23 2020 touch + -rwxr-xr-x 1 root root 22496 Sep 23 2020 true + -rwxr-xr-x 1 root root 9636 Feb 27 06:12 ulockmgr_server + -rwsr-xr-x 1 root root 22108 Jul 29 09:09 umount + -rwxr-xr-x 1 root root 22520 Sep 23 2020 uname + -rwxr-xr-x 2 root root 2346 Mar 3 13:30 uncompress + -rwxr-xr-x 1 root root 96764 Sep 23 2020 vdir + -rwxr-xr-x 1 root root 38512 Jul 29 09:09 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/23481/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy @@ -371,7 +405,7 @@ Get: 152 http://deb.debian.org/debian bullseye/main armhf ruby-simplecov-html all 0.12.3-1 [404 kB] Get: 153 http://deb.debian.org/debian bullseye/main armhf ruby-simplecov all 0.19.1-1 [51.6 kB] Get: 154 http://deb.debian.org/debian bullseye/main armhf ruby-webmock all 3.8.3-1 [64.3 kB] -Fetched 44.1 MB in 12s (3681 kB/s) +Fetched 44.1 MB in 16s (2740 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 ... 19398 files and directories currently installed.) @@ -1012,7 +1046,8 @@ Building tag database... -> Finished parsing the build-deps I: Building the package -I: Running cd /build/ruby-httparty-0.18.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-httparty_0.18.1-2_source.changes +hostname: Name or service not known +I: Running cd /build/ruby-httparty-0.18.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-httparty_0.18.1-2_source.changes dpkg-buildpackage: info: source package ruby-httparty dpkg-buildpackage: info: source version 0.18.1-2 dpkg-buildpackage: info: source distribution unstable @@ -1047,7 +1082,7 @@ dh_auto_install -O--buildsystem=ruby dh_ruby --install /build/ruby-httparty-0.18.1/debian/ruby-httparty dh_ruby --install -/usr/bin/ruby2.7 -S gem build --config-file /dev/null --verbose /tmp/d20210823-24500-b61c6s/gemspec +/usr/bin/ruby2.7 -S gem build --config-file /dev/null --verbose /tmp/d20210824-9276-gjupqp/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 multi_xml (>= 0.5.2) is not recommended @@ -1058,7 +1093,7 @@ Name: httparty Version: 0.18.1 File: httparty-0.18.1.gem -/usr/bin/ruby2.7 -S gem install --config-file /dev/null --verbose --local --verbose --no-document --ignore-dependencies --install-dir debian/ruby-httparty/usr/share/rubygems-integration/all /tmp/d20210823-24500-b61c6s/httparty-0.18.1.gem +/usr/bin/ruby2.7 -S gem install --config-file /dev/null --verbose --local --verbose --no-document --ignore-dependencies --install-dir debian/ruby-httparty/usr/share/rubygems-integration/all /tmp/d20210824-9276-gjupqp/httparty-0.18.1.gem Failed to load /dev/null because it doesn't contain valid YAML hash /build/ruby-httparty-0.18.1/debian/ruby-httparty/usr/share/rubygems-integration/all/gems/httparty-0.18.1/bin/httparty /build/ruby-httparty-0.18.1/debian/ruby-httparty/usr/share/rubygems-integration/all/gems/httparty-0.18.1/docs/README.md @@ -1101,7 +1136,7 @@ rm -rf extensions cd gems/httparty-0.18.1 rm -f -chmod 644 lib/httparty.rb lib/httparty/request/body.rb lib/httparty/request/multipart_boundary.rb lib/httparty/response.rb lib/httparty/connection_adapter.rb lib/httparty/response_fragment.rb lib/httparty/version.rb lib/httparty/net_digest_auth.rb lib/httparty/module_inheritable_attributes.rb lib/httparty/response/headers.rb lib/httparty/text_encoder.rb lib/httparty/headers_processor.rb lib/httparty/exceptions.rb lib/httparty/parser.rb lib/httparty/utils.rb lib/httparty/cookie_hash.rb lib/httparty/hash_conversions.rb lib/httparty/request.rb lib/httparty/logger/logger.rb lib/httparty/logger/curl_formatter.rb lib/httparty/logger/apache_formatter.rb lib/httparty/logger/logstash_formatter.rb +chmod 644 lib/httparty.rb lib/httparty/request/body.rb lib/httparty/request/multipart_boundary.rb lib/httparty/cookie_hash.rb lib/httparty/module_inheritable_attributes.rb lib/httparty/response.rb lib/httparty/connection_adapter.rb lib/httparty/text_encoder.rb lib/httparty/request.rb lib/httparty/response/headers.rb lib/httparty/version.rb lib/httparty/parser.rb lib/httparty/utils.rb lib/httparty/headers_processor.rb lib/httparty/logger/curl_formatter.rb lib/httparty/logger/logstash_formatter.rb lib/httparty/logger/logger.rb lib/httparty/logger/apache_formatter.rb lib/httparty/net_digest_auth.rb lib/httparty/hash_conversions.rb lib/httparty/response_fragment.rb lib/httparty/exceptions.rb find lib/ -type d -empty -delete cd - cd - @@ -1125,590 +1160,43 @@ All examples were filtered out; ignoring {:focus=>true} -Randomized with seed 11612 +Randomized with seed 25444 -HTTParty::Logger::CurlFormatter - #format - formats a response in a style that resembles a -v curl - when request is logged - and request's option 'base_uri' is present - logs url - and headers are present - logs Headers - logs headers keys - and headers are not present - not log Headers - and query is present - logs query params - logs Query - when request raw_body is present - not logs request body - and request's option 'base_uri' is not present - logs url - and query is not present - not logs Query - when response is logged - logs body - logs http version and response code - logs headers - -HTTParty::CookieHash - #to_cookie_string - should not mutate the hash - should not include client side only cookies - should not include SameSite attribute - should format the key/value pairs, delimited by semi-colons - should not include client side only cookies even when attributes use camal case - #add_cookies - with a string - should overwrite any existing key - should add new key/value pairs to the hash - should handle an empty cookie parameter - should handle '=' within cookie value - with other class - should error - with a hash - should add new key/value pairs to the hash - should overwrite any existing key - -HTTParty::HeadersProcessor - when global and request specific headers are set - returns merged global and request specific headers - when headers are not set at all - returns empty hash - when only global headers are set - returns stringified global headers - when headers are dynamic - returns processed global and request specific headers - when only request specific headers are set - returns stringified request specific headers - -HTTParty::Request - SSL certificate verification -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept': SSL_accept returned=1 errno=0 state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept' - from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' - should fail when using ssl_ca_file and the server uses an unrecognized certificate authority - should work when using ssl_ca_file with a certificate authority - should work when no trusted CA list is specified, when the verify option is set to false -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept': SSL_accept returned=1 errno=0 state=error: tlsv1 alert internal error (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept' - from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' - should fail when using ssl_ca_file and the server uses a bogus hostname -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept': SSL_accept returned=1 errno=0 state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept' - from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' - should fail when using ssl_ca_path and the server uses a bogus hostname - should work when using ssl_ca_path with a certificate authority - should work when using ssl_ca_file with a self-signed CA -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept': SSL_accept returned=1 errno=0 state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept' - from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' - should fail when using ssl_ca_path and the server uses an unrecognized certificate authority - should work when no trusted CA list is specified, even with a bogus hostname, when the verify option is set to true -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept': SSL_accept returned=1 errno=0 state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept' - from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' - should fail when no trusted CA list is specified, with a bogus hostname, by default -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept': SSL_accept returned=1 errno=0 state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept' - from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' - should fail when no trusted CA list is specified, by default - should provide the certificate used by the server via peer_cert +HTTParty::Logger + .build + builds :curl style logger + raises error when formatter exists + builds :custom style logger + builds :logstash style logger + defaults format to :apache + defaults level to :info HTTParty::HashConversions + .to_params + creates a params string from a hash + nested params + creates a params string from a hash .normalize_param - value is a string - creates a params string - value is an array - creates a params string value is hash creates a params string value is an empty array creates a params string - .to_params - creates a params string from a hash - nested params - creates a params string from a hash - -HTTParty::Logger::ApacheFormatter - #format - formats a response in a style that resembles apache's access log - when there is a parsed response - can handle the Content-Length header - -HTTParty::ConnectionAdapter - initialization - takes a URI as input - sets the uri - raises an ArgumentError if the uri is nil - also accepts an optional options hash - raises an ArgumentError if the uri is a String - sets the options - .call - generates an HTTParty::ConnectionAdapter instance with the given uri and options - calls #connection on the connection adapter - #connection - the resulting connection - is expected to be an instance of Net::HTTP - when providing proxy address and port - is expected to be a proxy - as well as proxy user and password - #proxy_pass - is expected to eq "pass" - #proxy_user - is expected to eq "user" - #proxy_address - is expected to eq "1.2.3.4" - #proxy_port - is expected to eq 8080 - when not providing a proxy address - does not pass any proxy parameters to the connection - when providing PEM certificates - when scheme is not https - has no PEM certificate - when scheme is https - uses the provided PEM certificate - will verify the certificate - when options include verify=false - should not verify the certificate - when options include verify_peer=false - should not verify the certificate - when providing PKCS12 certificates - when scheme is not https - has no PKCS12 certificate - when scheme is https - will verify the certificate - uses the provided P12 certificate - when options include verify_peer=false - should not verify the certificate - when options include verify=false - should not verify the certificate - when dealing with IPv6 - strips brackets from the address - when timeout is set and read_timeout is set to 6 seconds - should override the timeout option - #read_timeout - is expected to eq 6 - #open_timeout - is expected to eq 5 - #write_timeout - is expected to eq 5 - when setting timeout - to 5 seconds - #write_timeout - is expected to eq 5 - #open_timeout - is expected to eq 5 - #read_timeout - is expected to eq 5 - and timeout is a string - doesn't set the timeout - when debug_output - is not provided - does not set_debug_output - is set to $stderr - has debug output set - when dealing with ssl - https scheme with non-standard port - is expected to use ssl - when ssl version is set - sets ssl version - uses the system cert_store, by default - is expected to use cert store # - https scheme with default port - is expected to use ssl - should use the specified cert store, when one is given - is expected to use cert store # - using port 443 for ssl - is expected to use ssl - when timeout is set and write_timeout is set to 8 seconds - should override the timeout option - #write_timeout - is expected to eq 8 - when timeout is not set and open_timeout is set to 7 seconds - should not set the write_timeout - should not set the read_timeout - #open_timeout - is expected to eq 7 - when uri port is not defined - falls back to 443 port on https - is expected to equal 443 - falls back to 80 port on http - is expected to equal 80 - when providing a local bind address and port - #local_port - is expected to eq 12345 - #local_host - is expected to eq "127.0.0.1" - using port 80 - is expected not to use ssl - when timeout is set and open_timeout is set to 7 seconds - should override the timeout option - #write_timeout - is expected to eq 5 - #read_timeout - is expected to eq 5 - #open_timeout - is expected to eq 7 - when providing nil as proxy address - is expected not to be a proxy - does pass nil proxy parameters to the connection, this forces to not use a proxy - when timeout is not set and write_timeout is set to 8 seconds - should not set the read timeout - should not set the open timeout - #write_timeout - is expected to eq 8 - specifying ciphers - should set the ciphers on the connection - when max_retries is not set - doesn't set the max_retries - when timeout is not set - doesn't set the timeout - when setting max_retries - and max_retries is a string - doesn't set the max_retries - to 0 times - #max_retries - is expected to eq 0 - to 5 times - #max_retries - is expected to eq 5 - when timeout is not set and read_timeout is set to 6 seconds - should not set the open_timeout - should not set the write_timeout - #read_timeout - is expected to eq 6 - -HTTParty - pkcs12 - should set the p12 content - should set the password - default params - should be able to be updated - should default to empty hash - #maintain_method_across_redirects - sets the maintain_method_across_redirects option to false - sets maintain_method_across_redirects to true by default - debug_output - stores the $stderr stream by default - stores the given stream as a default_option - .normalize_base_uri - should not treat uri's with a port of 4430 as ssl - should not modify the parameter - should add http if not present for non ssl requests - should not remove https for ssl requests - should add https if not present for ssl requests - #ensure_method_maintained_across_redirects - should set maintain_method_across_redirects option if unspecified - should not set maintain_method_across_redirects option if value is present - format - should not allow funky format - does not reset parser to the default parser - sets the default parser - should allow xml - should only print each format once with an exception - should allow plain - should allow csv - should allow json - .disable_rails_query_string_format - sets the query string normalizer to HTTParty::Request::NON_RAILS_QUERY_STRING_NORMALIZER - grand parent with inherited callback - continues running the #inherited on the parent - #get - should be able parse response type csv automatically - should be able to get chunked html - should accept webcal URIs -[DEPRECATION] HTTParty will no longer override `response#nil?`. This functionality will be removed in future versions. Please, add explicit check `response.body.nil? || response.body.empty?`. For more info refer to: https://github.com/jnunemaker/httparty/issues/568 -/usr/share/rubygems-integration/all/gems/rspec-expectations-3.9.2/lib/rspec/matchers/built_in/be.rb:69:in `match' - should parse empty response fine - should be able parse response type json automatically - should be able parse response type xml automatically - should be able to get html - should raise an InvalidURIError on URIs that can't be parsed at all - should not get undefined method add_node for nil class for the following xml - should accept http URIs - should return an empty body if stream_body option is turned on - should accept https URIs - when streaming body - is expected to eq # - headers - should be able to be updated - should default to empty hash - overrides class headers with request headers - does not modify default_options when no arguments are passed - should pass options as argument to header block value - merges class headers with request headers - uses the class headers when sending a request - should be able to accept block as header value - when posting file - changes content-type headers to multipart/form-data - with cookies - doesnt modify default headers - adds cookies to the headers - adds optional cookies to the optional headers - utilizes the class-level cookies - when headers passed as symbols - converts default headers to string - converts them to string - ssl_version - should set the ssl_version content - with multiple class definitions - should not run over each others options - ciphers - should set the ciphers content - .follow_redirects - sets the follow_redirects option to false - sets follow redirects to true by default - default timeout - should raise an exception if unsupported type provided - should default to nil - should support floats - should support updating - head requests should follow redirects requesting HEAD only - should remain HEAD request across redirects, unless specified otherwise - connection_adapter - should set the connection_adapter - should set the connection_adapter_options when provided - should process a request with a connection from the adapter - should not set the connection_adapter_options when not provided - two child classes inheriting from one parent - inherits default_cookies from the parent class - doesn't modify the parent's default options - doesn't modify hashes in the parent's default options - works with lambda values - should dup the proc on the child class - inherits default_options from the superclass - does not modify each others inherited attributes - doesn't modify the parent's default cookies - .raise_on - when parameters is a fixnum - sets raise_on option - when parameters is an array - sets raise_on option - #resend_on_redirect - sets resend_on_redirect to true by default - sets resend_on_redirect option to false - digest http authentication - should work - uri_adapter - with Addressable::URI - handles international domains - with custom URI Adaptor - should raise an ArgumentError if uri_adapter doesn't implement parse method - should set the uri_adapter - should process a request with a uri instance parsed from the uri_adapter - parser - does not validate format whe custom parser is a proc - should be able parse response with custom parser - should set parser options - raises UnsupportedFormat when the parser cannot handle the format - #no_follow - sets no_follow to false by default - sets the no_follow option to true - http_proxy - should set the proxy user and pass when they are provided - should set the address - cookies - should not be in the headers by default - should raise an ArgumentError if passed a non-Hash - should allow a cookie to be specified with a one-off request - in a class with multiple methods that use different cookies - should not allow cookies used in one method to carry over into other methods - when a cookie is set at the class level - should allow the class defaults to be overridden - should pass the proper cookies when requested multiple times - should include that cookie in the request - .query_string_normalizer - sets the query_string_normalizer option - pem - should set the password to nil if it's not provided - should set the pem content - should set the password - with explicit override of automatic redirect handling - should fail with redirected MOVE - should fail with redirected POST - should fail with redirected OPTIONS - should fail with redirected DELETE - should fail with redirected PATCH - should fail with redirected HEAD - should fail with redirected PUT - should fail with redirected COPY - should fail with redirected GET - should fail with redirected MKCOL - base uri - should have reader - should have writer - should not modify the parameter during assignment - basic http authentication - should work - -HTTParty::Response - returns a comma-delimited value when multiple values exist - responds to body - responds to hash methods - should send missing methods to delegate - responds to response - responds to headers - responds to parsed_response - does raise an error about itself when using #method - responds to anything parsed_response responds to - response to request - responds to predicates - does raise an error about itself when invoking a method that does not exist - allows headers to be accessed by mixed-case names in hash notation - returns response headers - response is array - should display the same as an array - should be able to iterate - should respond to array methods - should equal the string response object body - #is_a? - is expected to be truthy - is expected to be truthy - is expected to respond to #is_a? with 1 argument - semantic methods for response codes - major codes - is redirection - is client error - is server error - is success - is information - for specific codes - responds to not_acceptable? - responds to range_not_satisfiable? - responds to payload_too_large? - responds to see_other? - responds to request_entity_too_large? - responds to payment_required? - responds to found? - responds to created? - responds to uri_too_long? - responds to partial_content? - responds to switch_protocol? - responds to not_found? - responds to precondition_failed? - responds to accepted? - responds to length_required? - responds to use_proxy? - responds to temporary_redirect? - responds to conflict? - responds to multiple_choice? - responds to continue? - responds to no_content? - responds to gateway_timeout? - responds to reset_content? - responds to not_implemented? - responds to gone? - responds to ok? - responds to unauthorized? - responds to expectation_failed? - responds to requested_range_not_satisfiable? - responds to forbidden? - responds to internal_server_error? - responds to bad_request? - responds to service_unavailable? - responds to request_uri_too_long? - responds to proxy_authentication_required? - responds to multiple_choices? - responds to request_timeout? - responds to request_time_out? - responds to moved_permanently? - responds to bad_gateway? - responds to non_authoritative_information? - responds to gateway_time_out? - responds to version_not_supported? - responds to unsupported_media_type? - responds to method_not_allowed? - responds to not_modified? - #tap - is possible to tap into a response - #kind_of? - is expected to be truthy - is expected to be truthy - is expected to respond to #kind_of? with 1 argument - .underscore - works with one capitalized word - works with titlecase - works with all caps - marshalling - is expected to eq 200 - #inspect - works - headers - does not equal itself when not equivalent - does equal a hash - always equals itself - can initialize without headers - initialization - should set the Net::HTTP Response - should set code - should set code as an Integer - should set body - should set http_version - when raise_on is supplied - and response's status code is not in range - does not throw exception - and response's status code is in range - throws exception - -HTTParty::Error - HTTParty::DuplicateLocationHeader - #ancestors - is expected to include HTTParty::ResponseError - HTTParty::RedirectionTooDeep - #ancestors - is expected to include HTTParty::ResponseError - HTTParty::UnsupportedFormat - #ancestors - is expected to include HTTParty::Error - HTTParty::ResponseError - #ancestors - is expected to include HTTParty::Error - #ancestors - is expected to include StandardError - HTTParty::UnsupportedURIScheme - #ancestors - is expected to include HTTParty::Error - -HTTParty::Request::Body - #multipart? - when params does not respond to to_hash - is expected to equal false - when params responds to to_hash - when force_multipart is true - is expected to equal true - when it contains file - is expected to equal true - when it does not contain a file - is expected to eq false - #call - when params is string - is expected to eq "name=Bob%20Jones" - when params is hash - is expected to eq "people%5B%5D=Bob%20Jones&people%5B%5D=Mike%20Smith" - when params has file - is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[avatar]\";...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" - file object responds to original_filename - is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[avatar]\";...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" - when passing multipart as an option - is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[first_name...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" + value is a string + creates a params string + value is an array + creates a params string -HTTParty::Logger::LogstashFormatter - #format - formats a response to be compatible with Logstash +HTTParty::HeadersProcessor + when headers are dynamic + returns processed global and request specific headers + when only global headers are set + returns stringified global headers + when headers are not set at all + returns empty hash + when global and request specific headers are set + returns merged global and request specific headers + when only request specific headers are set + returns stringified request specific headers HTTParty::Request [DEPRECATION] HTTParty will no longer override `response#nil?`. This functionality will be removed in future versions. Please, add explicit check `response.body.nil? || response.body.empty?`. For more info refer to: https://github.com/jnunemaker/httparty/issues/568 @@ -1717,430 +1205,977 @@ /usr/share/rubygems-integration/all/gems/rspec-expectations-3.9.2/lib/rspec/matchers/built_in/be.rb:69:in `match' should not attempt to parse empty responses should not fail for missing mime type - ::NON_RAILS_QUERY_STRING_NORMALIZER - doesn't modify strings - when the query is a hash - correctly handles nil values - when the query is an array - URI encodes array values - doesn't include brackets - a request that 300 redirects - infinitely - should raise an exception + with Accept-Encoding header + should disable content decoding if present + should disable content decoding if present + should disable content decoding if present and lowercase + a request that 303 redirects once - should be handled by DELETE transparently - should be handled by PUT transparently - should keep cookies between redirects - should be handled by POST transparently - should be handled by MKCOL transparently + should be handled by HEAD transparently + should make resulting request a get request if it not already + should be handled by COPY transparently should be handled by PATCH transparently - should update cookies with redirects - should be handled by OPTIONS transparently should be handled by GET transparently - should be handled by COPY transparently - should keep track of cookies between redirects + should be handled by LOCK transparently + should be handled by PUT transparently + should be handled by OPTIONS transparently + should be handled by MKCOL transparently should log the redirection + should make resulting request a get request if options[:maintain_method_across_redirects] is true but options[:resend_on_redirect] is false should be handled by MOVE transparently - should make resulting request a get request if it not already - should not make resulting request a get request if options[:maintain_method_across_redirects] is true - should be handled by UNLOCK transparently - should be handled by HEAD transparently - should be handled by LOCK transparently + should be handled by DELETE transparently + should update cookies with redirects should handle multiple Set-Cookie headers between redirects - a request that 308 redirects + should keep cookies between redirects + should be handled by UNLOCK transparently + should make resulting request a get request if options[:maintain_method_across_redirects] is false + should be handled by POST transparently + should not make resulting request a get request if options[:maintain_method_across_redirects] and options[:resend_on_redirect] is true + should keep track of cookies between redirects infinitely should raise an exception + #setup_raw_request + when mulipart + when body contains file + sets header Content-Type: multipart/form-data; boundary= + and header Content-Type is provided + overwrites the header to: multipart/form-data; boundary= + when mulipart option is provided + sets header Content-Type: multipart/form-data; boundary= + when query_string_normalizer is set + sets the body to the return value of the proc + options + should use basic auth when configured + should use body_stream when configured + should normalize base uri when specified as request option + digest_auth + should maintain cookies returned from a 401 response + should merge cookies from request and a 401 response + should not send credentials more than once + should be used when configured and the response is 401 + should not be used when configured and the response is 200 + a request that 307 redirects once - should handle multiple Set-Cookie headers between redirects - should be handled by COPY transparently - should be handled by MKCOL transparently - should keep cookies between redirects - should keep track of cookies between redirects - should update cookies with redirects - should be handled by HEAD transparently - should be handled by LOCK transparently should be handled by OPTIONS transparently should maintain method in resulting request if options[:maintain_method_across_redirects] is false + should be handled by MKCOL transparently should maintain method in resulting request - should be handled by PATCH transparently - should be handled by UNLOCK transparently - should log the redirection + should be handled by HEAD transparently + should keep track of cookies between redirects + should be handled by COPY transparently should be handled by POST transparently + should be handled by GET transparently + should handle multiple Set-Cookie headers between redirects + should keep cookies between redirects + should be handled by UNLOCK transparently should be handled by MOVE transparently + should update cookies with redirects + should be handled by PATCH transparently should maintain method in resulting request if options[:maintain_method_across_redirects] is true - should be handled by GET transparently - should be handled by DELETE transparently + should log the redirection + should be handled by LOCK transparently should be handled by PUT transparently - with Accept-Encoding header - should disable content decoding if present - should disable content decoding if present and lowercase - should disable content decoding if present - a request that 303 redirects + should be handled by DELETE transparently infinitely should raise an exception + a request that 300 redirects once - should handle multiple Set-Cookie headers between redirects - should make resulting request a get request if it not already + should be handled by OPTIONS transparently + should keep cookies between redirects + should be handled by HEAD transparently + should be handled by GET transparently + should be handled by POST transparently + should be handled by PUT transparently + should log the redirection + should be handled by UNLOCK transparently should keep track of cookies between redirects - should not make resulting request a get request if options[:maintain_method_across_redirects] and options[:resend_on_redirect] is true - should be handled by DELETE transparently should be handled by MKCOL transparently - should be handled by GET transparently - should make resulting request a get request if options[:maintain_method_across_redirects] is false should update cookies with redirects should be handled by COPY transparently - should be handled by LOCK transparently - should be handled by MOVE transparently - should log the redirection - should be handled by POST transparently - should be handled by UNLOCK transparently - should be handled by OPTIONS transparently - should make resulting request a get request if options[:maintain_method_across_redirects] is true but options[:resend_on_redirect] is false - should keep cookies between redirects + should make resulting request a get request if it not already + should not make resulting request a get request if options[:maintain_method_across_redirects] is true should be handled by PATCH transparently - should be handled by HEAD transparently - should be handled by PUT transparently + should be handled by MOVE transparently + should be handled by LOCK transparently + should handle multiple Set-Cookie headers between redirects + should be handled by DELETE transparently + infinitely + should raise an exception + http + should get a connection from the connection_adapter + a request that returns 304 + should report 304 with a HEAD request + should report 304 with a MOVE request + should report 304 with a PUT request + should be handled by LOCK transparently + should report 304 with a DELETE request + should report 304 with a MKCOL request + should be handled by UNLOCK transparently + should not log the redirection + should report 304 with a OPTIONS request + should report 304 with a COPY request + should report 304 with a PATCH request + should report 304 with a GET request + should report 304 with a POST request ::JSON_API_QUERY_STRING_NORMALIZER doesn't modify strings when the query is a hash correctly handles nil values when the query is an array - URI encodes array values doesn't include brackets - options - should use body_stream when configured - should normalize base uri when specified as request option - should use basic auth when configured - digest_auth - should not send credentials more than once - should merge cookies from request and a 401 response - should not be used when configured and the response is 200 - should be used when configured and the response is 401 - should maintain cookies returned from a 401 response - #send_authorization_header? - basic_auth - should send Authorization header when redirecting to a different port on the same host - should send Authorization header when redirecting to a relative path - should not send Authorization header when redirecting to a different host - should send Authorization header when redirecting to the same host - #format_from_mimetype - should handle text/xml - returns nil for an unrecognized mimetype - should handle application/csv - should handle text/csv - should handle text/json - should handle text/comma-separated-values - returns nil when using a default parser - should handle application/json - should handle application/hal+json - should handle application/xml - should handle application/javascript - should handle application/vnd.api+json - should handle text/javascript - a request that 302 redirects + URI encodes array values + a request that 308 redirects + infinitely + should raise an exception once - should be handled by HEAD transparently - should keep cookies between redirects - should not make resulting request a get request if options[:maintain_method_across_redirects] is true should update cookies with redirects - should be handled by MOVE transparently + should be handled by OPTIONS transparently + should be handled by POST transparently + should be handled by COPY transparently should be handled by MKCOL transparently - should be handled by UNLOCK transparently - should be handled by DELETE transparently + should be handled by HEAD transparently + should maintain method in resulting request should be handled by PATCH transparently - should be handled by COPY transparently - should be handled by LOCK transparently should be handled by GET transparently - should make resulting request a get request if it not already - should be handled by POST transparently - should be handled by PUT transparently - should keep track of cookies between redirects + should be handled by LOCK transparently + should keep cookies between redirects should handle multiple Set-Cookie headers between redirects - should be handled by OPTIONS transparently should log the redirection - infinitely - should raise an exception + should keep track of cookies between redirects + should maintain method in resulting request if options[:maintain_method_across_redirects] is true + should be handled by MOVE transparently + should be handled by PUT transparently + should be handled by UNLOCK transparently + should maintain method in resulting request if options[:maintain_method_across_redirects] is false + should be handled by DELETE transparently + #format + request has been made + returns the content-type from the last response when the option is not set + returns format option + request yet to be made + returns format option + returns nil format + argument validation + should raise argument error if digest_auth is not a hash + should raise argument error if options method is not http accepted method + should raise argument error if basic_auth and digest_auth are both present + should raise argument error if http method is post and query is not hash + should raise argument error if basic_auth is not a hash + should raise RedirectionTooDeep error if limit is negative + should raise argument error if headers is not a hash + with POST http method + should raise argument error if query is not a hash #uri + query strings + does not append an ampersand when queries are embedded in paths + respects the query string normalization proc + does not duplicate query string parameters when uri is called twice + does not add an empty query string when default_params are blank + when representing an array + returns a Rails style query string redirects returns correct path when the server sets the location header to a full uri returns correct path when the server sets the location header to a network-path reference returns correct path when the server sets the location header to a filename location header is an absolute path - returns correct path when location has leading slash returns the correct path when location has no leading slash - query strings - does not duplicate query string parameters when uri is called twice - respects the query string normalization proc - does not add an empty query string when default_params are blank - does not append an ampersand when queries are embedded in paths - when representing an array - returns a Rails style query string - a request that 305 redirects - infinitely - should raise an exception + returns correct path when location has leading slash + initialization + sets parser to the optional parser + sets parser to HTTParty::Parser + sets connection_adapter to the optional connection_adapter + sets connection_adapter to HTTParty::ConnectionAdapter + when basic authentication credentials provided in uri + when basic auth options was set explicitly + uses basic auth from url anyway + when basic auth options wasn't set explicitly + sets basic auth from uri + when using a query string + when sending an array with only one element + sets correct query + and it has an empty array + sets correct query string + #send_authorization_header? + basic_auth + should send Authorization header when redirecting to the same host + should send Authorization header when redirecting to a different port on the same host + should send Authorization header when redirecting to a relative path + should not send Authorization header when redirecting to a different host + a request that 301 redirects once - should not make resulting request a get request if options[:maintain_method_across_redirects] is true - should be handled by MOVE transparently + should be handled by UNLOCK transparently + should be handled by COPY transparently should be handled by PUT transparently + should be handled by PATCH transparently + should be handled by OPTIONS transparently + should be handled by POST transparently + should be handled by DELETE transparently + should handle multiple Set-Cookie headers between redirects + should not make resulting request a get request if options[:maintain_method_across_redirects] is true + should keep cookies between redirects + should keep track of cookies between redirects should update cookies with redirects - should be handled by LOCK transparently should make resulting request a get request if it not already + should be handled by LOCK transparently should be handled by MKCOL transparently - should be handled by HEAD transparently - should be handled by COPY transparently - should handle multiple Set-Cookie headers between redirects - should keep cookies between redirects - should be handled by PATCH transparently - should be handled by OPTIONS transparently should be handled by GET transparently - should be handled by UNLOCK transparently - should keep track of cookies between redirects - should be handled by DELETE transparently - should be handled by POST transparently should log the redirection - a request that 307 redirects + should be handled by HEAD transparently + should be handled by MOVE transparently infinitely should raise an exception + #format_from_mimetype + should handle application/json + returns nil when using a default parser + should handle application/vnd.api+json + should handle application/javascript + should handle text/xml + returns nil for an unrecognized mimetype + should handle text/javascript + should handle application/csv + should handle text/csv + should handle application/hal+json + should handle application/xml + should handle text/json + should handle text/comma-separated-values + a request that 305 redirects once - should keep track of cookies between redirects + should be handled by LOCK transparently + should be handled by DELETE transparently + should keep cookies between redirects + should be handled by COPY transparently + should make resulting request a get request if it not already should be handled by MKCOL transparently + should be handled by OPTIONS transparently + should handle multiple Set-Cookie headers between redirects + should be handled by GET transparently + should be handled by POST transparently should be handled by PATCH transparently + should keep track of cookies between redirects should be handled by PUT transparently - should be handled by HEAD transparently - should be handled by MOVE transparently - should handle multiple Set-Cookie headers between redirects + should not make resulting request a get request if options[:maintain_method_across_redirects] is true should log the redirection - should be handled by POST transparently - should maintain method in resulting request - should maintain method in resulting request if options[:maintain_method_across_redirects] is false - should maintain method in resulting request if options[:maintain_method_across_redirects] is true - should update cookies with redirects - should be handled by DELETE transparently - should be handled by LOCK transparently - should be handled by COPY transparently + should be handled by HEAD transparently should be handled by UNLOCK transparently - should keep cookies between redirects - should be handled by GET transparently - should be handled by OPTIONS transparently - #format - request yet to be made - returns format option - returns nil format - request has been made - returns the content-type from the last response when the option is not set - returns format option - a request that returns 304 - should report 304 with a MOVE request - should report 304 with a DELETE request - should not log the redirection - should report 304 with a POST request - should report 304 with a PUT request - should report 304 with a OPTIONS request - should report 304 with a COPY request - should be handled by UNLOCK transparently - should be handled by LOCK transparently - should report 304 with a PATCH request - should report 304 with a MKCOL request - should report 304 with a GET request - should report 304 with a HEAD request - argument validation - should raise argument error if options method is not http accepted method - should raise RedirectionTooDeep error if limit is negative - should raise argument error if digest_auth is not a hash - should raise argument error if http method is post and query is not hash - should raise argument error if headers is not a hash - should raise argument error if basic_auth is not a hash - should raise argument error if basic_auth and digest_auth are both present + should update cookies with redirects + should be handled by MOVE transparently + infinitely + should raise an exception parsing responses - should process utf-16 charset with big endian bom correctly - should handle json automatically + should perform no encoding if the content type is specified but no charset is specified + should handle utf-8 bom in xml should perform no encoding if the charset is not available - should handle xml automatically + should handle utf-8 bom in json should include any HTTP headers in the returned response + should handle xml automatically should process response with a nil body - should perform no encoding if the content type is specified but no charset is specified should assume utf-16 little endian if options has been chosen should handle csv automatically - should handle utf-8 bom in json - should handle utf-8 bom in xml + should handle json automatically + should process utf-16 charset with big endian bom correctly when assume_utf16_is_big_endian is true - should process utf-16 charset with little endian bom correctly processes stubbed frozen body correctly + should process utf-16 charset with little endian bom correctly when body has ascii-8bit encoding processes quoted charset in content type properly - processes charset in content type properly if it has a different case processes charset in content type properly + processes charset in content type properly if it has a different case when stubed body is frozen processes frozen body correctly with non-200 responses - should return a valid object for 5xx response should return a valid object for 4xx response + should return a valid object for 5xx response parses response lazily so codes can be checked prior 3xx responses returns the HTTParty::Response when the 300 does not contain a location header - calls block given to perform with each redirect (PENDING: Temporarily skipped with xit) - raises an error if redirect has duplicate location header - handles multiple redirects and relative location headers on different hosts redirects including port - redirects if a 300 contains a location header [DEPRECATION] HTTParty will no longer override `response#nil?`. This functionality will be removed in future versions. Please, add explicit check `response.body.nil? || response.body.empty?`. For more info refer to: https://github.com/jnunemaker/httparty/issues/568 /usr/share/rubygems-integration/all/gems/rspec-expectations-3.9.2/lib/rspec/matchers/built_in/be.rb:69:in `match' returns a valid object for 304 not modified + handles multiple redirects and relative location headers on different hosts + calls block given to perform with each redirect (PENDING: Temporarily skipped with xit) + redirects if a 300 contains a location header + raises an error if redirect has duplicate location header redirects if a 300 contains a relative location header - initialization - sets parser to the optional parser - sets connection_adapter to the optional connection_adapter - sets parser to HTTParty::Parser - sets connection_adapter to HTTParty::ConnectionAdapter - when using a query string - when sending an array with only one element - sets correct query - and it has an empty array - sets correct query string - when basic authentication credentials provided in uri - when basic auth options wasn't set explicitly - sets basic auth from uri - when basic auth options was set explicitly - uses basic auth from url anyway - a request that 301 redirects - infinitely - should raise an exception + a request that 302 redirects once - should be handled by GET transparently - should be handled by POST transparently - should be handled by MKCOL transparently - should update cookies with redirects - should be handled by HEAD transparently - should keep cookies between redirects should be handled by UNLOCK transparently - should be handled by DELETE transparently - should be handled by LOCK transparently - should make resulting request a get request if it not already - should be handled by PUT transparently - should be handled by PATCH transparently should be handled by COPY transparently - should handle multiple Set-Cookie headers between redirects should be handled by MOVE transparently + should be handled by LOCK transparently + should handle multiple Set-Cookie headers between redirects + should be handled by OPTIONS transparently should log the redirection + should be handled by MKCOL transparently + should be handled by HEAD transparently + should be handled by POST transparently should keep track of cookies between redirects should not make resulting request a get request if options[:maintain_method_across_redirects] is true - should be handled by OPTIONS transparently - with POST http method - should raise argument error if query is not a hash - http - should get a connection from the connection_adapter - #setup_raw_request - when query_string_normalizer is set - sets the body to the return value of the proc - when mulipart - when mulipart option is provided - sets header Content-Type: multipart/form-data; boundary= - when body contains file - sets header Content-Type: multipart/form-data; boundary= - and header Content-Type is provided - overwrites the header to: multipart/form-data; boundary= + should be handled by PUT transparently + should be handled by PATCH transparently + should be handled by GET transparently + should update cookies with redirects + should keep cookies between redirects + should be handled by DELETE transparently + should make resulting request a get request if it not already + infinitely + should raise an exception + ::NON_RAILS_QUERY_STRING_NORMALIZER + doesn't modify strings + when the query is a hash + correctly handles nil values + when the query is an array + URI encodes array values + doesn't include brackets + +HTTParty::CookieHash + #add_cookies + with a string + should overwrite any existing key + should handle '=' within cookie value + should add new key/value pairs to the hash + should handle an empty cookie parameter + with other class + should error + with a hash + should add new key/value pairs to the hash + should overwrite any existing key + #to_cookie_string + should not include client side only cookies even when attributes use camal case + should not include SameSite attribute + should format the key/value pairs, delimited by semi-colons + should not mutate the hash + should not include client side only cookies + +HTTParty::Response + responds to predicates + responds to hash methods + responds to anything parsed_response responds to + responds to headers + does raise an error about itself when using #method + responds to parsed_response + allows headers to be accessed by mixed-case names in hash notation + does raise an error about itself when invoking a method that does not exist + responds to body + should send missing methods to delegate + returns response headers + responds to response + returns a comma-delimited value when multiple values exist + response to request + #is_a? + is expected to respond to #is_a? with 1 argument + is expected to be truthy + is expected to be truthy + response is array + should display the same as an array + should respond to array methods + should equal the string response object body + should be able to iterate + marshalling + is expected to eq 200 + initialization + should set the Net::HTTP Response + should set code + should set code as an Integer + should set body + should set http_version + when raise_on is supplied + and response's status code is not in range + does not throw exception + and response's status code is in range + throws exception + #kind_of? + is expected to be truthy + is expected to be truthy + is expected to respond to #kind_of? with 1 argument + semantic methods for response codes + for specific codes + responds to not_acceptable? + responds to method_not_allowed? + responds to uri_too_long? + responds to no_content? + responds to multiple_choice? + responds to bad_request? + responds to partial_content? + responds to see_other? + responds to ok? + responds to proxy_authentication_required? + responds to gateway_time_out? + responds to payment_required? + responds to precondition_failed? + responds to conflict? + responds to forbidden? + responds to unauthorized? + responds to accepted? + responds to bad_gateway? + responds to non_authoritative_information? + responds to requested_range_not_satisfiable? + responds to expectation_failed? + responds to reset_content? + responds to temporary_redirect? + responds to payload_too_large? + responds to found? + responds to gateway_timeout? + responds to unsupported_media_type? + responds to request_uri_too_long? + responds to not_found? + responds to moved_permanently? + responds to request_time_out? + responds to version_not_supported? + responds to request_entity_too_large? + responds to not_implemented? + responds to use_proxy? + responds to created? + responds to gone? + responds to request_timeout? + responds to continue? + responds to multiple_choices? + responds to service_unavailable? + responds to length_required? + responds to not_modified? + responds to internal_server_error? + responds to switch_protocol? + responds to range_not_satisfiable? + major codes + is success + is client error + is server error + is redirection + is information + headers + can initialize without headers + always equals itself + does not equal itself when not equivalent + does equal a hash + .underscore + works with all caps + works with titlecase + works with one capitalized word + #tap + is possible to tap into a response + #inspect + works Net::HTTPHeader::DigestAuthenticator + with algorithm specified + should recognise algorithm was specified + should set the algorithm header with specified quality of protection (qop) - should set cnonce - should set nonce-count - should set digest-uri should set response + should set digest-uri + should set qop + should set nonce-count should set prefix should set username - should set qop - with a cookie value in the response header - should set cookie header - when quality of protection (qop) is unquoted - should still set qop + should set cnonce + with http basic auth response when net digest auth expected + should not fail with md5-sess algorithm specified - should recognise algorithm was specified - should set response using md5-sess algorithm - should set the algorithm header - with algorithm specified should set the algorithm header + should set response using md5-sess algorithm should recognise algorithm was specified + with an opaque value in the response header + should set opaque + when quality of protection (qop) is unquoted + should still set qop Net::HTTPHeader#digest_auth should set the authorization header with unspecified quality of protection (qop) - should set username - should not set qop - should not set nonce-count should not set cnonce - should set prefix - should set digest-uri should set response + should not set nonce-count + should not set qop + should set username + should set digest-uri + should set prefix without a cookie value in the response header should set empty cookie header array + without an opaque valid in the response header + should not set opaque with multiple authenticate headers + should set username + should set digest-uri + should set qop should set prefix should set cnonce - should set nonce-count - should set qop should set response - should set digest-uri - should set username - with an opaque value in the response header - should set opaque - with http basic auth response when net digest auth expected - should not fail - without an opaque valid in the response header - should not set opaque + should set nonce-count + with a cookie value in the response header + should set cookie header -HTTParty::Logger - .build - defaults format to :apache - defaults level to :info - raises error when formatter exists - builds :curl style logger - builds :custom style logger - builds :logstash style logger +HTTParty::Request::Body + #call + when params is hash + is expected to eq "people%5B%5D=Bob%20Jones&people%5B%5D=Mike%20Smith" + when params has file + is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[avatar]\";...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" + file object responds to original_filename + is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[avatar]\";...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" + when passing multipart as an option + is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[first_name...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" + when params is string + is expected to eq "name=Bob%20Jones" + #multipart? + when params responds to to_hash + when it does not contain a file + is expected to eq false + when it contains file + is expected to equal true + when force_multipart is true + is expected to equal true + when params does not respond to to_hash + is expected to equal false -HTTParty::ResponseFragment - has access to delegators - access to fragment +HTTParty::ConnectionAdapter + #connection + the resulting connection + is expected to be an instance of Net::HTTP + when providing PEM certificates + when scheme is https + uses the provided PEM certificate + will verify the certificate + when options include verify_peer=false + should not verify the certificate + when options include verify=false + should not verify the certificate + when scheme is not https + has no PEM certificate + when timeout is not set and read_timeout is set to 6 seconds + should not set the write_timeout + should not set the open_timeout + #read_timeout + is expected to eq 6 + when setting max_retries + to 0 times + #max_retries + is expected to eq 0 + and max_retries is a string + doesn't set the max_retries + to 5 times + #max_retries + is expected to eq 5 + when uri port is not defined + falls back to 443 port on https + is expected to equal 443 + falls back to 80 port on http + is expected to equal 80 + using port 80 + is expected not to use ssl + when timeout is not set and write_timeout is set to 8 seconds + should not set the read timeout + should not set the open timeout + #write_timeout + is expected to eq 8 + when providing nil as proxy address + is expected not to be a proxy + does pass nil proxy parameters to the connection, this forces to not use a proxy + when dealing with IPv6 + strips brackets from the address + when debug_output + is set to $stderr + has debug output set + is not provided + does not set_debug_output + when timeout is set and write_timeout is set to 8 seconds + should override the timeout option + #write_timeout + is expected to eq 8 + when timeout is not set + doesn't set the timeout + when not providing a proxy address + does not pass any proxy parameters to the connection + when timeout is set and read_timeout is set to 6 seconds + should override the timeout option + #open_timeout + is expected to eq 5 + #write_timeout + is expected to eq 5 + #read_timeout + is expected to eq 6 + when setting timeout + and timeout is a string + doesn't set the timeout + to 5 seconds + #read_timeout + is expected to eq 5 + #open_timeout + is expected to eq 5 + #write_timeout + is expected to eq 5 + when providing a local bind address and port + #local_port + is expected to eq 12345 + #local_host + is expected to eq "127.0.0.1" + when providing PKCS12 certificates + when scheme is https + uses the provided P12 certificate + will verify the certificate + when options include verify=false + should not verify the certificate + when options include verify_peer=false + should not verify the certificate + when scheme is not https + has no PKCS12 certificate + when dealing with ssl + https scheme with default port + is expected to use ssl + should use the specified cert store, when one is given + is expected to use cert store # + when ssl version is set + sets ssl version + https scheme with non-standard port + is expected to use ssl + using port 443 for ssl + is expected to use ssl + uses the system cert_store, by default + is expected to use cert store # + specifying ciphers + should set the ciphers on the connection + when timeout is set and open_timeout is set to 7 seconds + should override the timeout option + #open_timeout + is expected to eq 7 + #write_timeout + is expected to eq 5 + #read_timeout + is expected to eq 5 + when max_retries is not set + doesn't set the max_retries + when providing proxy address and port + is expected to be a proxy + as well as proxy user and password + #proxy_pass + is expected to eq "pass" + #proxy_user + is expected to eq "user" + #proxy_address + is expected to eq "1.2.3.4" + #proxy_port + is expected to eq 8080 + when timeout is not set and open_timeout is set to 7 seconds + should not set the read_timeout + should not set the write_timeout + #open_timeout + is expected to eq 7 + .call + generates an HTTParty::ConnectionAdapter instance with the given uri and options + calls #connection on the connection adapter + initialization + takes a URI as input + sets the options + sets the uri + raises an ArgumentError if the uri is nil + raises an ArgumentError if the uri is a String + also accepts an optional options hash + +HTTParty::Error + HTTParty::ResponseError + #ancestors + is expected to include HTTParty::Error + HTTParty::RedirectionTooDeep + #ancestors + is expected to include HTTParty::ResponseError + HTTParty::DuplicateLocationHeader + #ancestors + is expected to include HTTParty::ResponseError + HTTParty::UnsupportedFormat + #ancestors + is expected to include HTTParty::Error + HTTParty::UnsupportedURIScheme + #ancestors + is expected to include HTTParty::Error + #ancestors + is expected to include StandardError + +HTTParty::Logger::LogstashFormatter + #format + formats a response to be compatible with Logstash HTTParty::Parser .format_from_mimetype - returns a symbol representing the format mimetype returns nil when the mimetype is not supported - .formats - returns the SupportedFormats constant - returns the SupportedFormats constant for subclasses - .SupportedFormats - returns a hash + returns a symbol representing the format mimetype .call generates an HTTParty::Parser instance with the given body and format calls #parse on the parser + #supports_format? + utilizes the class method to determine if the format is supported parsers parses html by simply returning the body - parses json with JSON - parses xml with MultiXml parses csv with CSV parses plain text by simply returning the body - .supports_format? - returns false for an unsupported format - returns true for a supported format + parses json with JSON + parses xml with MultiXml + .SupportedFormats + returns a hash #parse_supported_format calls the parser for the given format when a parsing method does not exist for the given format - raises a useful exception message for subclasses raises an exception + raises a useful exception message for subclasses + .formats + returns the SupportedFormats constant for subclasses + returns the SupportedFormats constant #parse + returns nil for an empty body + ignores utf-8 bom parses ascii 8bit encoding + does not raise exceptions for bodies with invalid encodings returns nil for a body with spaces only - attempts to parse supported formats - returns nil for an empty body - returns the unparsed body when the format is unsupported - returns nil for a nil body returns nil for a 'null' body - ignores utf-8 bom parses frozen strings - does not raise exceptions for bodies with invalid encodings + returns the unparsed body when the format is unsupported + returns nil for a nil body + attempts to parse supported formats + .supports_format? + returns false for an unsupported format + returns true for a supported format .supported_formats returns a unique set of supported formats represented by symbols - #supports_format? - utilizes the class method to determine if the format is supported + +HTTParty::ResponseFragment + access to fragment + has access to delegators + +HTTParty + headers + should be able to be updated + does not modify default_options when no arguments are passed + merges class headers with request headers + uses the class headers when sending a request + should pass options as argument to header block value + should be able to accept block as header value + overrides class headers with request headers + should default to empty hash + when headers passed as symbols + converts default headers to string + converts them to string + when posting file + changes content-type headers to multipart/form-data + with cookies + adds cookies to the headers + adds optional cookies to the optional headers + doesnt modify default headers + utilizes the class-level cookies + ciphers + should set the ciphers content + #no_follow + sets no_follow to false by default + sets the no_follow option to true + with multiple class definitions + should not run over each others options + pkcs12 + should set the password + should set the p12 content + uri_adapter + with Addressable::URI + handles international domains + with custom URI Adaptor + should set the uri_adapter + should raise an ArgumentError if uri_adapter doesn't implement parse method + should process a request with a uri instance parsed from the uri_adapter + connection_adapter + should set the connection_adapter + should set the connection_adapter_options when provided + should process a request with a connection from the adapter + should not set the connection_adapter_options when not provided + #maintain_method_across_redirects + sets the maintain_method_across_redirects option to false + sets maintain_method_across_redirects to true by default + http_proxy + should set the address + should set the proxy user and pass when they are provided + parser + should be able parse response with custom parser + raises UnsupportedFormat when the parser cannot handle the format + does not validate format whe custom parser is a proc + should set parser options + ssl_version + should set the ssl_version content + basic http authentication + should work + format + should allow csv + should not allow funky format + should allow json + should allow plain + should only print each format once with an exception + should allow xml + sets the default parser + does not reset parser to the default parser + .disable_rails_query_string_format + sets the query string normalizer to HTTParty::Request::NON_RAILS_QUERY_STRING_NORMALIZER + two child classes inheriting from one parent + doesn't modify the parent's default cookies + doesn't modify the parent's default options + doesn't modify hashes in the parent's default options + inherits default_options from the superclass + does not modify each others inherited attributes + should dup the proc on the child class + inherits default_cookies from the parent class + works with lambda values + .query_string_normalizer + sets the query_string_normalizer option + default params + should be able to be updated + should default to empty hash + .raise_on + when parameters is a fixnum + sets raise_on option + when parameters is an array + sets raise_on option + base uri + should not modify the parameter during assignment + should have reader + should have writer + #ensure_method_maintained_across_redirects + should not set maintain_method_across_redirects option if value is present + should set maintain_method_across_redirects option if unspecified + #get + should be able parse response type json automatically + should be able parse response type xml automatically + should be able parse response type csv automatically + should accept http URIs + should not get undefined method add_node for nil class for the following xml + should return an empty body if stream_body option is turned on + should raise an InvalidURIError on URIs that can't be parsed at all + should be able to get html + should accept webcal URIs +[DEPRECATION] HTTParty will no longer override `response#nil?`. This functionality will be removed in future versions. Please, add explicit check `response.body.nil? || response.body.empty?`. For more info refer to: https://github.com/jnunemaker/httparty/issues/568 +/usr/share/rubygems-integration/all/gems/rspec-expectations-3.9.2/lib/rspec/matchers/built_in/be.rb:69:in `match' + should parse empty response fine + should be able to get chunked html + should accept https URIs + when streaming body + is expected to eq # + head requests should follow redirects requesting HEAD only + should remain HEAD request across redirects, unless specified otherwise + .normalize_base_uri + should not remove https for ssl requests + should add https if not present for ssl requests + should not treat uri's with a port of 4430 as ssl + should not modify the parameter + should add http if not present for non ssl requests + grand parent with inherited callback + continues running the #inherited on the parent + #resend_on_redirect + sets resend_on_redirect to true by default + sets resend_on_redirect option to false + cookies + should not be in the headers by default + should raise an ArgumentError if passed a non-Hash + should allow a cookie to be specified with a one-off request + when a cookie is set at the class level + should allow the class defaults to be overridden + should pass the proper cookies when requested multiple times + should include that cookie in the request + in a class with multiple methods that use different cookies + should not allow cookies used in one method to carry over into other methods + digest http authentication + should work + with explicit override of automatic redirect handling + should fail with redirected COPY + should fail with redirected PUT + should fail with redirected DELETE + should fail with redirected HEAD + should fail with redirected GET + should fail with redirected MKCOL + should fail with redirected OPTIONS + should fail with redirected PATCH + should fail with redirected POST + should fail with redirected MOVE + .follow_redirects + sets the follow_redirects option to false + sets follow redirects to true by default + pem + should set the password + should set the password to nil if it's not provided + should set the pem content + default timeout + should support floats + should support updating + should default to nil + should raise an exception if unsupported type provided + debug_output + stores the $stderr stream by default + stores the given stream as a default_option + +HTTParty::Request + SSL certificate verification +# terminated with exception (report_on_exception is true): +/usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept': SSL_accept returned=1 errno=0 state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept' + from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:56:in `thread_main' + from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' + should fail when using ssl_ca_path and the server uses a bogus hostname +# terminated with exception (report_on_exception is true): +/usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept': SSL_accept returned=1 errno=0 state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept' + from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:56:in `thread_main' + from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' + should fail when no trusted CA list is specified, with a bogus hostname, by default +# terminated with exception (report_on_exception is true): +/usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept': SSL_accept returned=1 errno=0 state=error: tlsv1 alert internal error (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept' + from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:56:in `thread_main' + from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' + should fail when using ssl_ca_file and the server uses a bogus hostname + should work when no trusted CA list is specified, when the verify option is set to false +# terminated with exception (report_on_exception is true): +/usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept': SSL_accept returned=1 errno=0 state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept' + from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:56:in `thread_main' + from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' + should fail when using ssl_ca_file and the server uses an unrecognized certificate authority +# terminated with exception (report_on_exception is true): +/usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept': SSL_accept returned=1 errno=0 state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept' + from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:56:in `thread_main' + from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' + should fail when no trusted CA list is specified, by default + should work when no trusted CA list is specified, even with a bogus hostname, when the verify option is set to true + should provide the certificate used by the server via peer_cert + should work when using ssl_ca_file with a self-signed CA +# terminated with exception (report_on_exception is true): +/usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept': SSL_accept returned=1 errno=0 state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/2.7.0/openssl/ssl.rb:486:in `accept' + from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:56:in `thread_main' + from /build/ruby-httparty-0.18.1/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' + should fail when using ssl_ca_path and the server uses an unrecognized certificate authority + should work when using ssl_ca_file with a certificate authority + should work when using ssl_ca_path with a certificate authority + +HTTParty::Logger::ApacheFormatter + #format + formats a response in a style that resembles apache's access log + when there is a parsed response + can handle the Content-Length header + +HTTParty::Logger::CurlFormatter + #format + formats a response in a style that resembles a -v curl + when request is logged + and headers are present + logs Headers + logs headers keys + when request raw_body is present + not logs request body + and headers are not present + not log Headers + and request's option 'base_uri' is not present + logs url + and request's option 'base_uri' is present + logs url + and query is present + logs query params + logs Query + and query is not present + not logs Query + when response is logged + logs headers + logs body + logs http version and response code Pending: (Failures listed here are expected and do not affect your suite's status) @@ -2148,54 +2183,54 @@ # Temporarily skipped with xit # ./spec/httparty/request_spec.rb:641 -Top 10 slowest examples (1.23 seconds, 38.5% of total time): - HTTParty::Request SSL certificate verification should work when no trusted CA list is specified, when the verify option is set to false - 0.17398 seconds ./spec/httparty/ssl_spec.rb:19 +Top 10 slowest examples (3.31 seconds, 23.2% of total time): + HTTParty#get should be able parse response type xml automatically + 0.79443 seconds ./spec/httparty_spec.rb:906 + HTTParty::Request SSL certificate verification should work when using ssl_ca_file with a self-signed CA + 0.40728 seconds ./spec/httparty/ssl_spec.rb:33 HTTParty::Request SSL certificate verification should provide the certificate used by the server via peer_cert - 0.16743 seconds ./spec/httparty/ssl_spec.rb:74 + 0.39758 seconds ./spec/httparty/ssl_spec.rb:74 HTTParty::Request SSL certificate verification should work when no trusted CA list is specified, even with a bogus hostname, when the verify option is set to true - 0.15902 seconds ./spec/httparty/ssl_spec.rb:29 + 0.31184 seconds ./spec/httparty/ssl_spec.rb:29 HTTParty::Request SSL certificate verification should work when using ssl_ca_file with a certificate authority - 0.15384 seconds ./spec/httparty/ssl_spec.rb:37 - HTTParty::Request SSL certificate verification should work when using ssl_ca_file with a self-signed CA - 0.14932 seconds ./spec/httparty/ssl_spec.rb:33 - HTTParty#get should be able parse response type xml automatically - 0.13109 seconds ./spec/httparty_spec.rb:906 - HTTParty::Request SSL certificate verification should fail when using ssl_ca_file and the server uses a bogus hostname - 0.08263 seconds ./spec/httparty/ssl_spec.rb:62 - HTTParty::Request SSL certificate verification should fail when no trusted CA list is specified, with a bogus hostname, by default - 0.07829 seconds ./spec/httparty/ssl_spec.rb:23 + 0.30027 seconds ./spec/httparty/ssl_spec.rb:37 + HTTParty::Request SSL certificate verification should work when no trusted CA list is specified, when the verify option is set to false + 0.29729 seconds ./spec/httparty/ssl_spec.rb:19 HTTParty::Request SSL certificate verification should fail when using ssl_ca_path and the server uses an unrecognized certificate authority - 0.069 seconds ./spec/httparty/ssl_spec.rb:56 + 0.21814 seconds ./spec/httparty/ssl_spec.rb:56 + HTTParty::Request SSL certificate verification should fail when using ssl_ca_path and the server uses a bogus hostname + 0.20464 seconds ./spec/httparty/ssl_spec.rb:68 HTTParty::Request SSL certificate verification should fail when no trusted CA list is specified, by default - 0.06812 seconds ./spec/httparty/ssl_spec.rb:13 + 0.19262 seconds ./spec/httparty/ssl_spec.rb:13 + HTTParty::Request SSL certificate verification should fail when using ssl_ca_file and the server uses an unrecognized certificate authority + 0.18951 seconds ./spec/httparty/ssl_spec.rb:50 Top 10 slowest example groups: HTTParty::Request - 0.10142 seconds average (1.22 seconds / 12 examples) ./spec/httparty/ssl_spec.rb:3 + 0.24623 seconds average (2.95 seconds / 12 examples) ./spec/httparty/ssl_spec.rb:3 + HTTParty::Logger::LogstashFormatter + 0.0361 seconds average (0.0361 seconds / 1 example) ./spec/httparty/logger/logstash_formatter_spec.rb:3 + HTTParty::Logger::ApacheFormatter + 0.02637 seconds average (0.05273 seconds / 2 examples) ./spec/httparty/logger/apache_formatter_spec.rb:3 HTTParty::Logger::CurlFormatter - 0.00523 seconds average (0.06801 seconds / 13 examples) ./spec/httparty/logger/curl_formatter_spec.rb:3 + 0.02345 seconds average (0.30491 seconds / 13 examples) ./spec/httparty/logger/curl_formatter_spec.rb:3 HTTParty::Request - 0.00383 seconds average (0.98809 seconds / 258 examples) ./spec/httparty/request_spec.rb:3 + 0.02319 seconds average (5.98 seconds / 258 examples) ./spec/httparty/request_spec.rb:3 HTTParty - 0.00336 seconds average (0.39339 seconds / 117 examples) ./spec/httparty_spec.rb:3 - HTTParty::HeadersProcessor - 0.00336 seconds average (0.0168 seconds / 5 examples) ./spec/httparty/headers_processor_spec.rb:3 - HTTParty::ResponseFragment - 0.00327 seconds average (0.00653 seconds / 2 examples) ./spec/httparty/response_fragment_spec.rb:3 - HTTParty::Logger::ApacheFormatter - 0.00284 seconds average (0.00569 seconds / 2 examples) ./spec/httparty/logger/apache_formatter_spec.rb:3 - HTTParty::Logger::LogstashFormatter - 0.00279 seconds average (0.00279 seconds / 1 example) ./spec/httparty/logger/logstash_formatter_spec.rb:3 - HTTParty::ConnectionAdapter - 0.00231 seconds average (0.16185 seconds / 70 examples) ./spec/httparty/connection_adapter_spec.rb:3 + 0.01831 seconds average (2.14 seconds / 117 examples) ./spec/httparty_spec.rb:3 + HTTParty::Error + 0.01598 seconds average (0.0959 seconds / 6 examples) ./spec/httparty/exception_spec.rb:3 HTTParty::Request::Body - 0.00212 seconds average (0.01907 seconds / 9 examples) ./spec/httparty/request/body_spec.rb:6 + 0.01325 seconds average (0.11928 seconds / 9 examples) ./spec/httparty/request/body_spec.rb:6 + HTTParty::ConnectionAdapter + 0.01184 seconds average (0.82864 seconds / 70 examples) ./spec/httparty/connection_adapter_spec.rb:3 + Net::HTTPHeader::DigestAuthenticator + 0.01161 seconds average (0.38321 seconds / 33 examples) ./spec/httparty/net_digest_auth_spec.rb:3 -Finished in 3.2 seconds (files took 1.85 seconds to load) +Finished in 14.27 seconds (files took 15.62 seconds to load) 673 examples, 0 failures, 1 pending -Randomized with seed 11612 +Randomized with seed 25444 Coverage report generated for RSpec to /build/ruby-httparty-0.18.1/coverage. 996 / 1033 LOC (96.42%) covered. @@ -2236,12 +2271,14 @@ dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: not including original source code in upload I: copying local configuration +I: user script /srv/workspace/pbuilder/23481/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/23481/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/12788 and its subdirectories -I: Current time: Mon Aug 23 12:52:18 -12 2021 -I: pbuilder-time-stamp: 1629766338 +I: removing directory /srv/workspace/pbuilder/23481 and its subdirectories +I: Current time: Tue Aug 24 15:01:54 +14 2021 +I: pbuilder-time-stamp: 1629766914