Diff of the two buildlogs: -- --- b1/build.log 2024-06-08 08:38:51.703878906 +0000 +++ b2/build.log 2024-06-08 08:39:50.481379471 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Fri Jun 7 20:38:01 -12 2024 -I: pbuilder-time-stamp: 1717835881 +I: Current time: Sat Jul 12 05:01:55 +14 2025 +I: pbuilder-time-stamp: 1752246115 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/unstable-reproducible-base.tgz] I: copying local configuration @@ -30,52 +30,84 @@ dpkg-source: info: applying clean_spec_helper.patch I: Not using root during the build. I: Installing the build-deps -I: user script /srv/workspace/pbuilder/473036/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/821157/tmp/hooks/D01_modify_environment starting +debug: Running on codethink03-arm64. +I: Changing host+domainname to test build reproducibility +I: Adding a custom variable just for the fun of it... +I: Changing /bin/sh to bash +'/bin/sh' -> '/bin/bash' +lrwxrwxrwx 1 root root 9 Jul 11 15:02 /bin/sh -> /bin/bash +I: Setting pbuilder2's login shell to /bin/bash +I: Setting pbuilder2's GECOS to second user,second room,second work-phone,second home-phone,second other +I: user script /srv/workspace/pbuilder/821157/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/821157/tmp/hooks/D02_print_environment starting I: set - BUILDDIR='/build/reproducible-path' - BUILDUSERGECOS='first user,first room,first work-phone,first home-phone,first other' - BUILDUSERNAME='pbuilder1' - BUILD_ARCH='arm64' - DEBIAN_FRONTEND='noninteractive' + BASH=/bin/sh + BASHOPTS=checkwinsize:cmdhist:complete_fullquote:extquote:force_fignore:globasciiranges:globskipdots:hostcomplete:interactive_comments:patsub_replacement:progcomp:promptvars:sourcepath + BASH_ALIASES=() + BASH_ARGC=() + BASH_ARGV=() + BASH_CMDS=() + BASH_LINENO=([0]="12" [1]="0") + BASH_LOADABLES_PATH=/usr/local/lib/bash:/usr/lib/bash:/opt/local/lib/bash:/usr/pkg/lib/bash:/opt/pkg/lib/bash:. + BASH_SOURCE=([0]="/tmp/hooks/D02_print_environment" [1]="/tmp/hooks/D02_print_environment") + BASH_VERSINFO=([0]="5" [1]="2" [2]="21" [3]="1" [4]="release" [5]="aarch64-unknown-linux-gnu") + BASH_VERSION='5.2.21(1)-release' + BUILDDIR=/build/reproducible-path + BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' + BUILDUSERNAME=pbuilder2 + BUILD_ARCH=arm64 + DEBIAN_FRONTEND=noninteractive DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=12 ' - DISTRIBUTION='unstable' - HOME='/root' - HOST_ARCH='arm64' + DIRSTACK=() + DISTRIBUTION=unstable + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=aarch64 + HOST_ARCH=arm64 IFS=' ' - INVOCATION_ID='63226515ada846e7a368d089769caff8' - 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='473036' - PS1='# ' - PS2='> ' + INVOCATION_ID=af8df01553b546d98fc04dee262a4e45 + LANG=C + LANGUAGE=nl_BE:nl + LC_ALL=C + MACHTYPE=aarch64-unknown-linux-gnu + MAIL=/var/mail/root + OPTERR=1 + OPTIND=1 + OSTYPE=linux-gnu + PATH=/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path + PBCURRENTCOMMANDLINEOPERATION=build + PBUILDER_OPERATION=build + PBUILDER_PKGDATADIR=/usr/share/pbuilder + PBUILDER_PKGLIBDIR=/usr/lib/pbuilder + PBUILDER_SYSCONFDIR=/etc + PIPESTATUS=([0]="0") + POSIXLY_CORRECT=y + PPID=821157 PS4='+ ' - PWD='/' - SHELL='/bin/bash' - SHLVL='2' - SUDO_COMMAND='/usr/bin/timeout -k 18.1h 18h /usr/bin/ionice -c 3 /usr/bin/nice /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.OASPC3tY/pbuilderrc_vWBi --distribution unstable --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.OASPC3tY/b1 --logfile b1/build.log ruby-httparty_0.21.0-1.dsc' - SUDO_GID='109' - SUDO_UID='104' - SUDO_USER='jenkins' - TERM='unknown' - TZ='/usr/share/zoneinfo/Etc/GMT+12' - USER='root' - _='/usr/bin/systemd-run' - http_proxy='http://192.168.101.4:3128' + PWD=/ + SHELL=/bin/bash + SHELLOPTS=braceexpand:errexit:hashall:interactive-comments:posix + SHLVL=3 + SUDO_COMMAND='/usr/bin/timeout -k 24.1h 24h /usr/bin/ionice -c 3 /usr/bin/nice -n 11 /usr/bin/unshare --uts -- /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.OASPC3tY/pbuilderrc_2f2W --distribution unstable --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.OASPC3tY/b2 --logfile b2/build.log ruby-httparty_0.21.0-1.dsc' + SUDO_GID=109 + SUDO_UID=104 + SUDO_USER=jenkins + TERM=unknown + TZ=/usr/share/zoneinfo/Etc/GMT-14 + UID=0 + USER=root + _='I: set' + http_proxy=http://192.168.101.4:3128 I: uname -a - Linux codethink02-arm64 6.1.0-21-cloud-arm64 #1 SMP Debian 6.1.90-1 (2024-05-03) aarch64 GNU/Linux + Linux i-capture-the-hostname 6.1.0-21-cloud-arm64 #1 SMP Debian 6.1.90-1 (2024-05-03) aarch64 GNU/Linux I: ls -l /bin - lrwxrwxrwx 1 root root 7 Jun 5 22:35 /bin -> usr/bin -I: user script /srv/workspace/pbuilder/473036/tmp/hooks/D02_print_environment finished + lrwxrwxrwx 1 root root 7 Jun 5 2024 /bin -> usr/bin +I: user script /srv/workspace/pbuilder/821157/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy @@ -264,7 +296,7 @@ Get: 135 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-mocks all 3.13.0c0e0m0s1-2 [81.3 kB] Get: 136 http://deb.debian.org/debian unstable/main arm64 ruby-rspec all 3.13.0c0e0m0s1-2 [5184 B] Get: 137 http://deb.debian.org/debian unstable/main arm64 ruby-webmock all 3.18.1-2 [66.2 kB] -Fetched 41.6 MB in 0s (128 MB/s) +Fetched 41.6 MB in 0s (139 MB/s) debconf: delaying package configuration, since apt-utils is not installed Selecting previously unselected package liblocale-gettext-perl. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 19763 files and directories currently installed.) @@ -720,8 +752,8 @@ Setting up tzdata (2024a-4) ... Current default time zone: 'Etc/UTC' -Local time is now: Sat Jun 8 08:38:28 UTC 2024. -Universal Time is now: Sat Jun 8 08:38:28 UTC 2024. +Local time is now: Fri Jul 11 15:02:21 UTC 2025. +Universal Time is now: Fri Jul 11 15:02:21 UTC 2025. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up autotools-dev (20220109.1) ... @@ -846,7 +878,11 @@ Building tag database... -> Finished parsing the build-deps I: Building the package -I: Running cd /build/reproducible-path/ruby-httparty-0.21.0/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-genchanges -S > ../ruby-httparty_0.21.0-1_source.changes +I: user script /srv/workspace/pbuilder/821157/tmp/hooks/A99_set_merged_usr starting +Not re-configuring usrmerge for unstable +I: user script /srv/workspace/pbuilder/821157/tmp/hooks/A99_set_merged_usr finished +hostname: Name or service not known +I: Running cd /build/reproducible-path/ruby-httparty-0.21.0/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-genchanges -S > ../ruby-httparty_0.21.0-1_source.changes dpkg-buildpackage: info: source package ruby-httparty dpkg-buildpackage: info: source version 0.21.0-1 dpkg-buildpackage: info: source distribution unstable @@ -878,7 +914,7 @@ dh_prep -O--buildsystem=ruby dh_auto_install --destdir=debian/ruby-httparty/ -O--buildsystem=ruby dh_ruby --install /build/reproducible-path/ruby-httparty-0.21.0/debian/ruby-httparty -/usr/bin/ruby3.1 -S gem build --config-file /dev/null --verbose /tmp/d20240607-485218-enl7uz/gemspec +/usr/bin/ruby3.1 -S gem build --config-file /dev/null --verbose /tmp/d20250712-833100-s7r0e9/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 @@ -892,7 +928,7 @@ Name: httparty Version: 0.21.0 File: httparty-0.21.0.gem -/usr/bin/ruby3.1 -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/d20240607-485218-enl7uz/httparty-0.21.0.gem +/usr/bin/ruby3.1 -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/d20250712-833100-s7r0e9/httparty-0.21.0.gem Failed to load /dev/null because it doesn't contain valid YAML hash /build/reproducible-path/ruby-httparty-0.21.0/debian/ruby-httparty/usr/share/rubygems-integration/all/gems/httparty-0.21.0/bin/httparty /build/reproducible-path/ruby-httparty-0.21.0/debian/ruby-httparty/usr/share/rubygems-integration/all/gems/httparty-0.21.0/lib/httparty.rb @@ -960,38 +996,533 @@ All examples were filtered out; ignoring {:focus=>true} -Randomized with seed 31731 +Randomized with seed 15937 + +HTTParty + #get + should not get undefined method add_node for nil class for the following xml + should be able to get html + should be able parse response type csv automatically + should be able to get chunked html + should accept webcal URIs + should return an empty body if stream_body option is turned on + should accept https URIs + should be able parse response type xml automatically +[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.13.0/lib/rspec/matchers/built_in/be.rb:69:in `match' + should parse empty response fine + should raise an InvalidURIError on URIs that can't be parsed at all + should accept http URIs + should be able parse response type json automatically + when streaming body + is expected to eq # + parser + should set parser options + 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 + two child classes inheriting from one parent + should dup the proc on the child class + does not modify each others inherited attributes + doesn't modify the parent's default cookies + doesn't modify hashes in the parent's default options + doesn't modify the parent's default options + inherits default_cookies from the parent class + inherits default_options from the superclass + works with lambda values + #no_follow + sets no_follow to false by default + sets the no_follow option to true + connection_adapter + should set the connection_adapter_options when provided + should not set the connection_adapter_options when not provided + should process a request with a connection from the adapter + should set the connection_adapter + http_proxy + should set the address + should set the proxy user and pass when they are provided + debug_output + stores the $stderr stream by default + stores the given stream as a default_option + #resend_on_redirect + sets resend_on_redirect to true by default + sets resend_on_redirect option to false + .disable_rails_query_string_format + sets the query string normalizer to HTTParty::Request::NON_RAILS_QUERY_STRING_NORMALIZER + .normalize_base_uri + should add https if not present for ssl requests + should not remove https for ssl requests + should not treat uri's with a port of 4430 as ssl + should add http if not present for non ssl requests + should not modify the parameter + .query_string_normalizer + sets the query_string_normalizer option + base uri + should not modify the parameter during assignment + should have writer + should have reader + default timeout + should support floats + should raise an exception if unsupported type provided + should default to nil + should support updating + 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 + cookies + should raise an ArgumentError if passed a non-Hash + should allow a cookie to be specified with a one-off request + should not be in the headers by default + when a cookie is set at the class level + should allow the class defaults to be overridden + should include that cookie in the request + should pass the proper cookies when requested multiple times + 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 multiple class definitions + should not run over each others options + .follow_redirects + sets follow redirects to true by default + sets the follow_redirects option to false + ciphers + should set the ciphers content + headers + should be able to be updated + should default to empty hash + does not modify default_options when no arguments are passed + should be able to accept block as header value + merges class headers with request headers + uses the class headers when sending a request + should pass options as argument to header block value + overrides class headers with request headers + 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 + utilizes the class-level cookies + doesnt modify default headers + adds cookies to the headers + adds optional cookies to the optional headers + with explicit override of automatic redirect handling + should fail with redirected POST + should fail with redirected GET + should fail with redirected MKCOL + should fail with redirected PATCH + should fail with redirected PUT + should fail with redirected COPY + should fail with redirected OPTIONS + should fail with redirected DELETE + should fail with redirected MOVE + should fail with redirected HEAD + format + should allow csv + should not allow funky format + should allow xml + should allow plain + should allow json + should only print each format once with an exception + does not reset parser to the default parser + sets the default parser + #maintain_method_across_redirects + sets the maintain_method_across_redirects option to false + sets maintain_method_across_redirects to true by default + basic http authentication + should work + default params + should default to empty hash + should be able to be updated + .raise_on + when parameters is a fixnum + sets raise_on option + when parameters is an array + sets raise_on option + #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 + pem + should set the password + should set the pem content + should set the password to nil if it's not provided + grand parent with inherited callback + continues running the #inherited on the parent + pkcs12 + should set the p12 content + should set the password + head requests should follow redirects requesting HEAD only + should remain HEAD request across redirects, unless specified otherwise + ssl_version + should set the ssl_version content + +HTTParty::Logger + .build + defaults level to :info + builds :logstash style logger + defaults format to :apache + builds :curl style logger + builds :custom style logger + raises error when formatter exists + +HTTParty::ResponseFragment + has access to delegators + access to fragment + +HTTParty::ConnectionAdapter + .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 not providing a proxy address + does not pass any proxy parameters to the connection + when timeout is set and open_timeout is set to 7 seconds + should override the timeout option + #read_timeout + is expected to eq 5 + #write_timeout + is expected to eq 5 + #open_timeout + is expected to eq 7 + specifying ciphers + should set the ciphers on the connection + when providing PKCS12 certificates + when scheme is https + uses the provided P12 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 PKCS12 certificate + 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 + when providing nil as proxy address + does pass nil proxy parameters to the connection, this forces to not use a proxy + is expected not to be a proxy + when uri port is not defined + falls back to 80 port on http + is expected to equal 80 + falls back to 443 port on https + is expected to equal 443 + 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 + when providing proxy address and port + is expected to be a proxy + #proxy_address + is expected to eq "1.2.3.4" + #proxy_port + is expected to eq 8080 + as well as proxy user and password + #proxy_pass + is expected to eq "pass" + #proxy_user + is expected to eq "user" + when dealing with IPv6 + strips brackets from the address + when debug_output + is not provided + does not set_debug_output + is set to $stderr + has debug output set + when timeout is not set + doesn't set the timeout + 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_peer=false + should not verify the certificate + when options include verify=false + should not verify the certificate + when timeout is set and read_timeout is set to 6 seconds + should override the timeout option + #write_timeout + is expected to eq 5 + #read_timeout + is expected to eq 6 + #open_timeout + is expected to eq 5 + when setting 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 + and timeout is a string + doesn't set the timeout + when timeout is not set and write_timeout is set to 8 seconds + should not set the open timeout + should not set the read timeout + #write_timeout + is expected to eq 8 + when setting max_retries + to 0 times + #max_retries + is expected to eq 0 + to 5 times + #max_retries + is expected to eq 5 + and max_retries is a string + doesn't set the max_retries + when timeout is set and write_timeout is set to 8 seconds + should override the timeout option + #write_timeout + is expected to eq 8 + using port 80 + is expected not to use ssl + when max_retries is not set + doesn't set the max_retries + 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 dealing with ssl + https scheme with non-standard 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 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 + initialization + sets the uri + raises an ArgumentError if the uri is nil + raises an ArgumentError if the uri is a String + takes a URI as input + sets the options + also accepts an optional options hash + +HTTParty::CookieHash + #add_cookies + with other class + should error + with a hash + should overwrite any existing key + should add new key/value pairs to the hash + with a string + should add new key/value pairs to the hash + should overwrite any existing key + should handle '=' within cookie value + should handle an empty cookie parameter + #to_cookie_string + should not include SameSite attribute + should not include client side only cookies even when attributes use camal case + should not mutate the hash + should format the key/value pairs, delimited by semi-colons + should not include client side only cookies + +HTTParty::Logger::LogstashFormatter + #format + formats a response to be compatible with Logstash + +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 does not contain a file + is expected to eq false + when it contains file + is expected to equal true + #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 not to change `file.pos` + 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 file name contains [ " \r \n ] + is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[attachment...: 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" + 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" + +HTTParty::HeadersProcessor + 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 global headers are set + returns stringified global headers + when only request specific headers are set + returns stringified request specific headers + when headers are dynamic + returns processed global and request specific headers + +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 + should provide the certificate used by the server via peer_cert + should work when using ssl_ca_file with a certificate authority +# terminated with exception (report_on_exception is true): +/usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept': SSL_accept returned=1 errno=0 peeraddr=(null) state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept' + from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' + from /build/reproducible-path/ruby-httparty-0.21.0/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/3.1.0/openssl/ssl.rb:524:in `accept': SSL_accept returned=1 errno=0 peeraddr=(null) state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept' + from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' + from /build/reproducible-path/ruby-httparty-0.21.0/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 + 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/3.1.0/openssl/ssl.rb:524:in `accept': SSL_accept returned=1 errno=0 peeraddr=(null) state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept' + from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' + from /build/reproducible-path/ruby-httparty-0.21.0/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/3.1.0/openssl/ssl.rb:524:in `accept': SSL_accept returned=1 errno=0 peeraddr=(null) state=error: ssl/tls alert bad certificate (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept' + from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' + from /build/reproducible-path/ruby-httparty-0.21.0/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/3.1.0/openssl/ssl.rb:524:in `accept': SSL_accept returned=1 errno=0 peeraddr=(null) state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept' + from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' + from /build/reproducible-path/ruby-httparty-0.21.0/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 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/3.1.0/openssl/ssl.rb:524:in `accept': SSL_accept returned=1 errno=0 peeraddr=(null) state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept' + from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' + from /build/reproducible-path/ruby-httparty-0.21.0/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 + +HTTParty::Parser + .supports_format? + returns false for an unsupported format + returns true for a supported format + .SupportedFormats + returns a hash + #supports_format? + utilizes the class method to determine if the format is supported + #parse + returns nil for an empty body + does not raise exceptions for bodies with invalid encodings + attempts to parse supported formats + returns nil for a body with spaces only + parses frozen strings + parses ascii 8bit encoding + ignores utf-8 bom + returns the unparsed body when the format is unsupported + returns nil for a 'null' body + returns nil for a nil body + parsers + parses json with JSON + parses plain text by simply returning the body + parses csv with CSV + parses html by simply returning the body + parses xml with MultiXml + .supported_formats + returns a unique set of supported formats represented by symbols + .formats + returns the SupportedFormats constant for subclasses + returns the SupportedFormats constant + .call + generates an HTTParty::Parser instance with the given body and format + calls #parse on the parser + .format_from_mimetype + returns a symbol representing the format mimetype + returns nil when the mimetype is not supported + #parse_supported_format + calls the parser for the given format + when a parsing method does not exist for the given format + raises an exception + raises a useful exception message for subclasses + +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::HashConversions + .normalize_param + value is hash + creates a params string + value is an array + creates a params string + value is a string + 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::Decompressor + .SupportedEncodings + returns a hash #decompress - when encoding is "compress" - when ruby-lzws raises error - is expected to eq nil - when compress-lzw included - is expected to eq "foobar" - when LZW gem not included - behaves like returns nil - is expected to be nil - when ruby-lzws included - is expected to eq "foobar" - when encoding is "identity" - behaves like returns the body - is expected to eq "body" when body is nil behaves like returns nil is expected to be nil - when encoding is blank + when encoding is "none" behaves like returns the body is expected to eq "body" - when encoding is "none" + when encoding is "identity" + behaves like returns the body + is expected to eq "body" + when encoding is blank behaves like returns the body is expected to eq "body" when encoding is unsupported behaves like returns nil is expected to be nil - when encoding is nil - behaves like returns the body - is expected to eq "body" + when encoding is "br" + when brotli raises error + is expected to eq nil + when brotli included + is expected to eq "foobar" + when brotli gem not included + behaves like returns nil + is expected to be nil + when encoding is "compress" + when LZW gem not included + behaves like returns nil + is expected to be nil + when ruby-lzws included + is expected to eq "foobar" + when compress-lzw included + is expected to eq "foobar" + when ruby-lzws raises error + is expected to eq nil when body is blank is expected to eq " " when encoding is "zstd" @@ -1002,16 +1533,190 @@ when zstd-ruby gem not included behaves like returns nil is expected to be nil - when encoding is "br" - when brotli included - is expected to eq "foobar" - when brotli gem not included - behaves like returns nil - is expected to be nil - when brotli raises error - is expected to eq nil - .SupportedEncodings - returns a hash + when encoding is nil + behaves like returns the body + is expected to eq "body" + +Net::HTTPHeader::DigestAuthenticator + without a cookie value in the response header + should set empty cookie header array + with md5-sess algorithm specified + should recognise algorithm was specified + should set response using md5-sess algorithm + should set the algorithm header + with http basic auth response when net digest auth expected + should not fail + with specified quality of protection (qop) + should set prefix + should set cnonce + should set username + should set response + should set nonce-count + should set qop + should set digest-uri + 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 + without an opaque valid in the response header + should not set opaque + when quality of protection (qop) is unquoted + should still set qop + with algorithm specified + should recognise algorithm was specified + should set the algorithm header + with a cookie value in the response header + should set cookie header + with an opaque value in the response header + should set opaque + Net::HTTPHeader#digest_auth + should set the authorization header + with multiple authenticate headers + should set digest-uri + should set prefix + should set nonce-count + should set cnonce + should set qop + should set response + should set username + +HTTParty::Logger::CurlFormatter + #format + formats a response in a style that resembles a -v curl + when response is logged + logs headers + logs body + logs http version and response code + when request is logged + and request's option 'base_uri' is not present + logs url + and headers are not present + not log Headers + and headers are present + logs Headers + logs headers keys + and query is not present + not logs Query + and request's option 'base_uri' is present + logs url + when request raw_body is present + not logs request body + and query is present + logs Query + logs query params + +HTTParty::Response + responds to body + should send missing methods to delegate + responds to response + returns a comma-delimited value when multiple values exist + does raise an error about itself when using #method + responds to headers + responds to parsed_response + returns response headers + 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 + response to request + responds to predicates + responds to anything parsed_response responds to + responds to hash methods + #is_a? + is expected to be truthy + is expected to respond to #is_a? with 1 argument + is expected to be truthy + #inspect + works + #kind_of? + is expected to respond to #kind_of? with 1 argument + is expected to be truthy + is expected to be truthy + semantic methods for response codes + major codes + is information + is redirection + is server error + is client error + is success + for specific codes + responds to multiple_choice? + responds to method_not_allowed? + responds to not_implemented? + responds to multiple_choices? + responds to payment_required? + responds to see_other? + responds to request_uri_too_long? + responds to conflict? + responds to use_proxy? + responds to length_required? + responds to version_not_supported? + responds to continue? + responds to service_unavailable? + responds to gateway_time_out? + responds to non_authoritative_information? + responds to reset_content? + responds to unsupported_media_type? + responds to found? + responds to request_time_out? + responds to uri_too_long? + responds to no_content? + responds to payload_too_large? + responds to not_found? + responds to expectation_failed? + responds to gone? + responds to precondition_failed? + responds to partial_content? + responds to range_not_satisfiable? + responds to request_entity_too_large? + responds to requested_range_not_satisfiable? + responds to moved_permanently? + responds to switch_protocol? + responds to forbidden? + responds to accepted? + responds to not_modified? + responds to ok? + responds to bad_gateway? + responds to proxy_authentication_required? + responds to internal_server_error? + responds to created? + responds to bad_request? + responds to gateway_timeout? + responds to unauthorized? + responds to not_acceptable? + responds to temporary_redirect? + responds to request_timeout? + .underscore + works with titlecase + works with all caps + works with one capitalized word + response is array + should display the same as an array + should respond to array methods + should be able to iterate + should equal the string response object body + initialization + should set http_version + should set code as an Integer + should set code + should set body + should set the Net::HTTP Response + when raise_on is supplied + and response's status code is in range + throws exception + and response's status code is not in range + does not throw exception + marshalling + is expected to eq 200 + headers + does not equal itself when not equivalent + always equals itself + can initialize without headers + does equal a hash + #tap + is possible to tap into a response HTTParty::Request should not fail for missing mime type @@ -1020,1072 +1725,403 @@ [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.13.0/lib/rspec/matchers/built_in/be.rb:69:in `match' should not attempt to parse empty responses - a request that 303 redirects + a request that 300 redirects infinitely should raise an exception once - should make resulting request a get request if options[:maintain_method_across_redirects] is false - should be handled by UNLOCK transparently - should make resulting request a get request if it not already - should be handled by COPY transparently + should not make resulting request a get request if options[:maintain_method_across_redirects] is true + should be handled by LOCK transparently should keep track of cookies between redirects - should be handled by GET transparently + should log the redirection + should be handled by PATCH transparently + should handle multiple Set-Cookie headers between redirects should keep cookies between redirects should be handled by DELETE transparently should update cookies with redirects - should not make resulting request a get request if options[:maintain_method_across_redirects] and options[:resend_on_redirect] is true - should log the redirection - should be handled by MKCOL transparently - should be handled by HEAD transparently - should be handled by MOVE transparently - should handle multiple Set-Cookie headers between redirects - 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 OPTIONS transparently + should be handled by GET transparently should be handled by POST transparently + should make resulting request a get request if it not already + should be handled by OPTIONS transparently + should be handled by COPY transparently + should be handled by MOVE transparently should be handled by PUT transparently - should be handled by PATCH transparently - should be handled by LOCK transparently - ::JSON_API_QUERY_STRING_NORMALIZER - doesn't modify strings - when the query is an array - URI encodes array values - doesn't include brackets - when the query is a hash - correctly handles nil values + should be handled by MKCOL transparently + should be handled by UNLOCK transparently + should be handled by HEAD transparently + with POST http method + should raise argument error if query is not a hash + #send_authorization_header? + basic_auth + should send Authorization header when redirecting to the same host + should send Authorization header when redirecting to a relative path + should send Authorization header when redirecting to a different port on the same host + should not send Authorization header when redirecting to a different host + argument validation + should raise argument error if basic_auth and digest_auth are both present + should raise argument error if basic_auth is not a hash + should raise argument error if options method is not http accepted method + should raise argument error if headers is not a hash + should raise argument error if http method is post and query is not hash + should raise RedirectionTooDeep error if limit is negative + should raise argument error if digest_auth is not a hash + #setup_raw_request + when query_string_normalizer is set + sets the body to the return value of the proc + when multipart + 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= + #format_from_mimetype + should handle application/xml + should handle application/vnd.api+json + should handle application/javascript + should handle text/xml + returns nil for an unrecognized mimetype + should handle application/csv + returns nil when using a default parser + should handle application/hal+json + should handle text/json + should handle text/csv + should handle text/comma-separated-values + should handle application/json + should handle text/javascript parsing responses - should handle csv automatically - should handle utf-8 bom in json + should include any HTTP headers in the returned response should perform no encoding if the charset is not available + should handle utf-8 bom in xml should assume utf-16 little endian if options has been chosen - should include any HTTP headers in the returned response - should perform no encoding if the content type is specified but no charset is specified should handle json automatically should handle xml automatically - should handle utf-8 bom in xml + should handle csv automatically should process response with a nil body should process utf-16 charset with big endian bom correctly + should handle utf-8 bom in json + should perform no encoding if the content type is specified but no charset is specified with non-200 responses - should return a valid object for 4xx response parses response lazily so codes can be checked prior + should return a valid object for 4xx response should return a valid object for 5xx response 3xx responses - redirects including port [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.13.0/lib/rspec/matchers/built_in/be.rb:69:in `match' returns a valid object for 304 not modified - returns the HTTParty::Response when the 300 does not contain a location header + handles multiple redirects and relative location headers on different hosts raises an error if redirect has duplicate location header - calls block given to perform with each redirect (PENDING: Temporarily skipped with xit) + redirects including port redirects if a 300 contains a relative location header + returns the HTTParty::Response when the 300 does not contain a location header redirects if a 300 contains a location header - handles multiple redirects and relative location headers on different hosts - decompression - should remove the Content-Encoding header if uncompressed - should not decompress unrecognized Content-Encoding - should decompress the body and remove the Content-Encoding header - should not decompress the body if the :skip_decompression option is set + calls block given to perform with each redirect (PENDING: Temporarily skipped with xit) when body has ascii-8bit encoding - processes charset in content type properly - processes charset in content type properly if it has a different case 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 when stubed body is frozen processes frozen body correctly when assume_utf16_is_big_endian is true should process utf-16 charset with little endian bom correctly processes stubbed frozen body correctly - a request that 307 redirects + decompression + should remove the Content-Encoding header if uncompressed + should decompress the body and remove the Content-Encoding header + should not decompress the body if the :skip_decompression option is set + should not decompress unrecognized Content-Encoding + initialization + sets parser to the optional parser + sets connection_adapter to the optional connection_adapter + sets connection_adapter to HTTParty::ConnectionAdapter + sets parser to HTTParty::Parser + 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 + options + should use basic auth when configured + should normalize base uri when specified as request option + should use body_stream when configured + digest_auth + should merge cookies from request and a 401 response + should maintain cookies returned from a 401 response + should not be used when configured and the response is 200 + should not send credentials more than once + should be used when configured and the response is 401 + a request that 303 redirects infinitely should raise an exception once - should be handled by DELETE transparently - should update cookies with redirects - should be handled by POST transparently should keep cookies between redirects - should be handled by MKCOL transparently - should be handled by PATCH transparently - should be handled by LOCK transparently - should maintain method in resulting request - should keep track of cookies between redirects - should maintain method in resulting request if options[:maintain_method_across_redirects] is false + should make resulting request a get request if options[:maintain_method_across_redirects] is false + 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 be handled by GET transparently + should not make resulting request a get request if options[:maintain_method_across_redirects] and options[:resend_on_redirect] is true should handle multiple Set-Cookie headers between redirects - should be handled by COPY transparently should be handled by PUT transparently - should maintain method in resulting request if options[:maintain_method_across_redirects] is true - should be handled by MOVE transparently - should be handled by GET transparently - should be handled by OPTIONS transparently - should be handled by HEAD transparently - should log the redirection - should be handled by UNLOCK transparently - marshalling - properly marshals the request object - a request that returns 304 - should be handled by UNLOCK transparently - should be handled by LOCK transparently - should report 304 with a DELETE request - should report 304 with a PATCH request - should report 304 with a MOVE request - should not log the redirection - should report 304 with a POST request - should report 304 with a HEAD request - should report 304 with a PUT request - should report 304 with a OPTIONS request - should report 304 with a COPY request - should report 304 with a MKCOL request - should report 304 with a GET request - a request that 305 redirects - infinitely - should raise an exception - once - should be handled by HEAD transparently + should be handled by COPY transparently should be handled by PATCH transparently + should be handled by LOCK transparently + should be handled by MOVE transparently + should be handled by POST transparently should be handled by MKCOL transparently - should be handled by UNLOCK transparently - should be handled by PUT transparently - should handle multiple Set-Cookie headers between redirects + should be handled by HEAD transparently should be handled by DELETE transparently - should be handled by POST transparently - should keep cookies between redirects - should be handled by MOVE transparently - should not make resulting request a get request if options[:maintain_method_across_redirects] is true - should be handled by LOCK transparently - should keep track of cookies between redirects - should make resulting request a get request if it not already - should be handled by OPTIONS transparently - should update cookies with redirects - should log the redirection - should be handled by COPY transparently - should be handled by GET transparently - a request that 300 redirects - infinitely - should raise an exception - once - should be handled by LOCK transparently + should be handled by UNLOCK transparently should keep track of cookies between redirects - should be handled by COPY transparently - should handle multiple Set-Cookie headers between redirects - should be handled by DELETE transparently should make resulting request a get request if it not already - should keep cookies between redirects should update cookies with redirects - should be handled by MOVE transparently - should not make resulting request a get request if options[:maintain_method_across_redirects] is true - should be handled by PATCH transparently should log the redirection - should be handled by PUT transparently - should be handled by UNLOCK transparently - should be handled by HEAD transparently - should be handled by POST transparently - should be handled by OPTIONS transparently - should be handled by GET transparently - should be handled by MKCOL transparently - #send_authorization_header? - basic_auth - should send Authorization header when redirecting to a different port on the same host - should not send Authorization header when redirecting to a different host - should send Authorization header when redirecting to the same host - should send Authorization header when redirecting to a relative path http should get a connection from the connection_adapter - ::NON_RAILS_QUERY_STRING_NORMALIZER + a request that returns 304 + should report 304 with a COPY request + should not log the redirection + should report 304 with a MOVE request + should report 304 with a PATCH request + should report 304 with a GET request + should report 304 with a OPTIONS request + should be handled by LOCK transparently + should report 304 with a DELETE request + should be handled by UNLOCK transparently + should report 304 with a MKCOL request + should report 304 with a PUT request + should report 304 with a POST request + should report 304 with a HEAD request + Net::HTTP decompression + with skip_decompression true + with Accept-Encoding and other headers specified + behaves like sets custom Accept-Encoding + is expected to eq "custom" + behaves like disables Net::HTTP decompression + is expected to eq false + with no headers specified + behaves like sets default Accept-Encoding + is expected to eq "gzip;q=1.0,deflate;q=0.6,identity;q=0.3" + behaves like disables Net::HTTP decompression + is expected to eq false + with accept-encoding (lowercase) specified + behaves like disables Net::HTTP decompression + is expected to eq false + behaves like sets custom Accept-Encoding + is expected to eq "custom" + with other headers specified + behaves like sets default Accept-Encoding + is expected to eq "gzip;q=1.0,deflate;q=0.6,identity;q=0.3" + behaves like disables Net::HTTP decompression + is expected to eq false + with Accept-Encoding specified + behaves like sets custom Accept-Encoding + is expected to eq "custom" + behaves like disables Net::HTTP decompression + is expected to eq false + with skip_decompression false (default) + with other headers specified + behaves like enables Net::HTTP decompression + is expected to eq true + behaves like sets default Accept-Encoding + is expected to eq "gzip;q=1.0,deflate;q=0.6,identity;q=0.3" + with accept-encoding (lowercase) specified + behaves like enables Net::HTTP decompression + is expected to eq true + behaves like sets custom Accept-Encoding + is expected to eq "custom" + with Accept-Encoding specified + behaves like enables Net::HTTP decompression + is expected to eq true + behaves like sets custom Accept-Encoding + is expected to eq "custom" + with Accept-Encoding and other headers specified + behaves like sets custom Accept-Encoding + is expected to eq "custom" + behaves like enables Net::HTTP decompression + is expected to eq true + with no headers specified + behaves like enables Net::HTTP decompression + is expected to eq true + behaves like sets default Accept-Encoding + is expected to eq "gzip;q=1.0,deflate;q=0.6,identity;q=0.3" + ::JSON_API_QUERY_STRING_NORMALIZER doesn't modify strings when the query is an array - doesn't include brackets URI encodes array values + doesn't include brackets when the query is a hash correctly handles nil values - a request that 308 redirects - once - should be handled by PATCH transparently - should update cookies with redirects - should be handled by PUT transparently - should maintain method in resulting request if options[:maintain_method_across_redirects] is true - should be handled by LOCK transparently - should be handled by UNLOCK transparently - should be handled by COPY transparently - should handle multiple Set-Cookie headers between redirects - should maintain method in resulting request if options[:maintain_method_across_redirects] is false - should be handled by GET transparently - should be handled by DELETE transparently - should be handled by OPTIONS transparently - should keep cookies between redirects - should keep track of cookies between redirects - should be handled by MKCOL transparently - should maintain method in resulting request - should be handled by POST transparently - should be handled by HEAD transparently - should log the redirection - should be handled by MOVE transparently - infinitely - should raise an exception - with POST http method - should raise argument error if query is not a hash #uri query strings does not duplicate query string parameters when uri is called twice respects the query string normalization proc - does not append an ampersand when queries are embedded in paths 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 redirects - returns correct path when the server sets the location header to a filename 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 the correct path when location has no leading slash returns correct path when location has leading slash - a request that 301 redirects + marshalling + properly marshals the request object + ::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 + doesn't include brackets + URI encodes array values + #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 307 redirects + once + should be handled by MKCOL transparently + should maintain method in resulting request if options[:maintain_method_across_redirects] is true + should be handled by LOCK transparently + should log the redirection + should be handled by HEAD transparently + should be handled by COPY transparently + should handle multiple Set-Cookie headers between redirects + should be handled by POST transparently + should be handled by GET transparently + should keep cookies between redirects + should update cookies with redirects + should be handled by MOVE transparently + should be handled by UNLOCK transparently + should be handled by PUT transparently + should maintain method in resulting request if options[:maintain_method_across_redirects] is false + should be handled by DELETE transparently + should maintain method in resulting request + should be handled by OPTIONS transparently + should keep track of cookies between redirects + should be handled by PATCH transparently + infinitely + should raise an exception + a request that 302 redirects infinitely should raise an exception once + should keep track of cookies between redirects + should make resulting request a get request if it not already + should be handled by UNLOCK transparently + should be handled by MKCOL transparently should be handled by GET transparently - should be handled by LOCK transparently - should be handled by DELETE transparently - should be handled by HEAD transparently - should not make resulting request a get request if options[:maintain_method_across_redirects] is true should log the redirection should keep cookies between redirects - should be handled by PATCH transparently - should be handled by MOVE transparently + should be handled by DELETE transparently + should be handled by PUT transparently should update cookies with redirects + should be handled by PATCH transparently should be handled by POST transparently - should keep track of cookies between redirects - should be handled by UNLOCK transparently + should not make resulting request a get request if options[:maintain_method_across_redirects] is true 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 be handled by COPY transparently + should be handled by LOCK transparently + should be handled by HEAD transparently + should be handled by MOVE transparently + a request that 305 redirects + infinitely + should raise an exception + once + should be handled by POST transparently + should be handled by UNLOCK transparently + should keep cookies between redirects + should be handled by HEAD transparently + should log the redirection + should be handled by PATCH transparently should be handled by PUT transparently + should be handled by LOCK transparently + should make resulting request a get request if it not already + should be handled by OPTIONS transparently should be handled by MKCOL transparently - #setup_raw_request - when multipart - 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 - #format - request yet to be made - returns nil format - returns format option - request has been made - returns the content-type from the last response when the option is not set - returns format option - Net::HTTP decompression - with skip_decompression false (default) - with other headers specified - behaves like sets default Accept-Encoding - is expected to eq "gzip;q=1.0,deflate;q=0.6,identity;q=0.3" - behaves like enables Net::HTTP decompression - is expected to eq true - with no headers specified - behaves like enables Net::HTTP decompression - is expected to eq true - behaves like sets default Accept-Encoding - is expected to eq "gzip;q=1.0,deflate;q=0.6,identity;q=0.3" - with accept-encoding (lowercase) specified - behaves like sets custom Accept-Encoding - is expected to eq "custom" - behaves like enables Net::HTTP decompression - is expected to eq true - with Accept-Encoding specified - behaves like sets custom Accept-Encoding - is expected to eq "custom" - behaves like enables Net::HTTP decompression - is expected to eq true - with Accept-Encoding and other headers specified - behaves like sets custom Accept-Encoding - is expected to eq "custom" - behaves like enables Net::HTTP decompression - is expected to eq true - with skip_decompression true - with other headers specified - behaves like sets default Accept-Encoding - is expected to eq "gzip;q=1.0,deflate;q=0.6,identity;q=0.3" - behaves like disables Net::HTTP decompression - is expected to eq false - with Accept-Encoding and other headers specified - behaves like disables Net::HTTP decompression - is expected to eq false - behaves like sets custom Accept-Encoding - is expected to eq "custom" - with accept-encoding (lowercase) specified - behaves like sets custom Accept-Encoding - is expected to eq "custom" - behaves like disables Net::HTTP decompression - is expected to eq false - with Accept-Encoding specified - behaves like disables Net::HTTP decompression - is expected to eq false - behaves like sets custom Accept-Encoding - is expected to eq "custom" - with no headers specified - behaves like disables Net::HTTP decompression - is expected to eq false - behaves like sets default Accept-Encoding - is expected to eq "gzip;q=1.0,deflate;q=0.6,identity;q=0.3" - 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 be used when configured and the response is 401 - should merge cookies from request and a 401 response - should not be used when configured and the response is 200 - should maintain cookies returned from a 401 response - should not send credentials more than once - 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 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 - and it has an empty array - sets correct query string - when sending an array with only one element - sets correct query - argument validation - 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 raise argument error if digest_auth is not a hash - should raise argument error if headers is not a hash - should raise argument error if http method is post and query is not hash - should raise argument error if options method is not http accepted method - should raise RedirectionTooDeep error if limit is negative - #format_from_mimetype - should handle application/javascript - should handle application/json - should handle text/comma-separated-values - should handle text/xml - should handle application/csv - should handle text/javascript - should handle text/json - should handle application/xml - should handle application/vnd.api+json - should handle application/hal+json - returns nil for an unrecognized mimetype - returns nil when using a default parser - should handle text/csv - a request that 302 redirects + should keep track of cookies between redirects + should be handled by COPY transparently + should not make resulting request a get request if options[:maintain_method_across_redirects] is true + should be handled by GET transparently + should handle multiple Set-Cookie headers between redirects + should be handled by MOVE transparently + should update cookies with redirects + should be handled by DELETE transparently + a request that 308 redirects + infinitely + should raise an exception once + should be handled by OPTIONS transparently should handle multiple Set-Cookie headers between redirects should be handled by POST transparently - should not make resulting request a get request if options[:maintain_method_across_redirects] is true should be handled by PUT transparently - should be handled by COPY transparently - should be handled by OPTIONS transparently - should update cookies with redirects should keep cookies between redirects should be handled by PATCH transparently + should maintain method in resulting request if options[:maintain_method_across_redirects] is false + should be handled by GET transparently + should be handled by MKCOL transparently should be handled by MOVE transparently - should make resulting request a get request if it not already + should log the redirection + should update cookies with redirects + should maintain method in resulting request + should be handled by LOCK transparently + should be handled by DELETE transparently should keep track of cookies between redirects should be handled by UNLOCK transparently - should log the redirection + should be handled by COPY transparently should be handled by HEAD transparently + should maintain method in resulting request if options[:maintain_method_across_redirects] is true + a request that 301 redirects + once + should log the redirection + should keep track of cookies between redirects + should make resulting request a get request if it not already should be handled by DELETE transparently + should be handled by PUT transparently + should keep cookies between redirects + should be handled by OPTIONS transparently + should be handled by POST transparently should be handled by GET transparently + should not make resulting request a get request if options[:maintain_method_across_redirects] is true + should handle multiple Set-Cookie headers between redirects + should update cookies with redirects + should be handled by MOVE transparently + should be handled by HEAD transparently + should be handled by UNLOCK transparently should be handled by LOCK transparently should be handled by MKCOL transparently + should be handled by COPY transparently + should be handled by PATCH transparently infinitely should raise an exception -HTTParty::Parser - .formats - returns the SupportedFormats constant - returns the SupportedFormats constant for subclasses - .call - generates an HTTParty::Parser instance with the given body and format - calls #parse on the parser - .format_from_mimetype - returns a symbol representing the format mimetype - returns nil when the mimetype is not supported - parsers - parses json with JSON - parses xml with MultiXml - parses html by simply returning the body - parses plain text by simply returning the body - parses csv with CSV - #parse - parses ascii 8bit encoding - returns nil for an empty body - ignores utf-8 bom - returns nil for a 'null' body - returns nil for a body with spaces only - attempts to parse supported formats - returns nil for a nil body - does not raise exceptions for bodies with invalid encodings - parses frozen strings - returns the unparsed body when the format is unsupported - .supports_format? - returns true for a supported format - returns false for an unsupported format - #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 - .SupportedFormats - returns a hash - #supports_format? - utilizes the class method to determine if the format is supported - .supported_formats - returns a unique set of supported formats represented by symbols - -HTTParty::Logger::CurlFormatter - #format - formats a response in a style that resembles a -v curl - when response is logged - logs http version and response code - logs headers - logs body - when request is logged - when request raw_body is present - not logs request body - and query is not present - not logs Query - and query is present - logs query params - logs Query - and headers are present - logs Headers - logs headers keys - and headers are not present - not log Headers - and request's option 'base_uri' is present - logs url - and request's option 'base_uri' is not present - logs url - -Net::HTTPHeader::DigestAuthenticator - with specified quality of protection (qop) - should set digest-uri - should set cnonce - should set nonce-count - should set qop - should set username - should set response - should set prefix - without an opaque valid in the response header - should not set opaque - with unspecified quality of protection (qop) - should set response - should not set nonce-count - should set digest-uri - should set username - should not set qop - should set prefix - should not set cnonce - with algorithm specified - should set the algorithm header - 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 - without a cookie value in the response header - should set empty cookie header array - Net::HTTPHeader#digest_auth - should set the authorization header - with http basic auth response when net digest auth expected - should not fail - with a cookie value in the response header - should set cookie header - with md5-sess algorithm specified - should set response using md5-sess algorithm - should recognise algorithm was specified - should set the algorithm header - with multiple authenticate headers - should set digest-uri - should set response - should set qop - should set username - should set nonce-count - should set cnonce - should set prefix - -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 not to change `file.pos` - 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 file name contains [ " \r \n ] - is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[attachment...: 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 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 does not contain a file - is expected to eq false - when it contains file - is expected to equal true - -HTTParty::Request - SSL certificate verification -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept': SSL_accept returned=1 errno=0 peeraddr=(null) state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/reproducible-path/ruby-httparty-0.21.0/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/3.1.0/openssl/ssl.rb:524:in `accept': SSL_accept returned=1 errno=0 peeraddr=(null) state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/reproducible-path/ruby-httparty-0.21.0/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 no trusted CA list is specified, even with a bogus hostname, when the verify option is set to true - should work when using ssl_ca_file with a self-signed CA - should work when using ssl_ca_path with a certificate authority -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept': SSL_accept returned=1 errno=0 peeraddr=(null) state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/reproducible-path/ruby-httparty-0.21.0/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 -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept': SSL_accept returned=1 errno=0 peeraddr=(null) state=error: ssl/tls alert bad certificate (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/reproducible-path/ruby-httparty-0.21.0/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 - should work when using ssl_ca_file with a certificate authority -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept': SSL_accept returned=1 errno=0 peeraddr=(null) state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' - should fail when no trusted CA list is specified, by default -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept': SSL_accept returned=1 errno=0 peeraddr=(null) state=error: tlsv1 alert unknown ca (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/3.1.0/openssl/ssl.rb:524:in `accept' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/reproducible-path/ruby-httparty-0.21.0/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 - should provide the certificate used by the server via peer_cert - -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::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 only request specific headers are set - returns stringified request specific headers - when headers are dynamic - returns processed global and request specific headers - -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 empty array - creates a params string - value is an array - creates a params string - value is hash - creates a params string - -HTTParty::ConnectionAdapter - #connection - the resulting connection - is expected to be an instance of Net::HTTP - when timeout is not set and write_timeout is set to 8 seconds - should not set the open timeout - should not set the read timeout - #write_timeout - is expected to eq 8 - 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 providing nil as proxy address - does pass nil proxy parameters to the connection, this forces to not use a proxy - is expected not to be a proxy - when dealing with ssl - using port 443 for ssl - is expected to use ssl - should use the specified cert store, when one is given - is expected to use cert store # - uses the system cert_store, by default - is expected to use cert store # - https scheme with non-standard port - is expected to use ssl - https scheme with default port - is expected to use ssl - when ssl version is set - sets ssl version - 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 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_port - is expected to eq 8080 - #proxy_address - is expected to eq "1.2.3.4" - when providing a local bind address and port - #local_host - is expected to eq "127.0.0.1" - #local_port - is expected to eq 12345 - specifying ciphers - should set the ciphers on the connection - using port 80 - is expected not to use ssl - 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 setting max_retries - to 5 times - #max_retries - is expected to eq 5 - and max_retries is a string - doesn't set the max_retries - to 0 times - #max_retries - is expected to eq 0 - when setting timeout - and timeout is a string - doesn't set the timeout - to 5 seconds - #write_timeout - is expected to eq 5 - #read_timeout - is expected to eq 5 - #open_timeout - is expected to eq 5 - when not providing a proxy address - does not pass any proxy parameters to the connection - when dealing with IPv6 - strips brackets from the address - when timeout is not set - doesn't set the timeout - 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 - uses the provided P12 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 debug_output - is not provided - does not set_debug_output - is set to $stderr - has debug output set - 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 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 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 - .call - calls #connection on the connection adapter - generates an HTTParty::ConnectionAdapter instance with the given uri and options - initialization - takes a URI as input - raises an ArgumentError if the uri is a String - raises an ArgumentError if the uri is nil - sets the options - sets the uri - also accepts an optional options hash - -HTTParty::CookieHash - #add_cookies - with a string - should handle an empty cookie parameter - should add new key/value pairs to the hash - should overwrite any existing key - should handle '=' within cookie value - with other class - should error - with a hash - should overwrite any existing key - should add new key/value pairs to the hash - #to_cookie_string - should not include client side only cookies even when attributes use camal case - should not include SameSite attribute - should not mutate the hash - should not include client side only cookies - should format the key/value pairs, delimited by semi-colons - -HTTParty - pem - should set the password - should set the password to nil if it's not provided - should set the pem content - cookies - should allow a cookie to be specified with a one-off request - should raise an ArgumentError if passed a non-Hash - should not be in the headers by default - when a cookie is set at the class level - should include that cookie in the request - should allow the class defaults to be overridden - should pass the proper cookies when requested multiple times - in a class with multiple methods that use different cookies - should not allow cookies used in one method to carry over into other methods - ciphers - should set the ciphers content - .raise_on - when parameters is a fixnum - sets raise_on option - when parameters is an array - sets raise_on option - 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 - doesn't modify the parent's default cookies - inherits default_cookies from the parent class - works with lambda values - should dup the proc on the child class - doesn't modify the parent's default options - does not modify each others inherited attributes - doesn't modify hashes in the parent's default options - inherits default_options from the superclass - grand parent with inherited callback - continues running the #inherited on the parent - #get - should accept webcal URIs - should be able parse response type xml automatically - should be able parse response type json automatically - should be able to get html - should be able to get chunked html -[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.13.0/lib/rspec/matchers/built_in/be.rb:69:in `match' - should parse empty response fine - should accept http URIs - 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 parse response type csv automatically - should accept https URIs - should not get undefined method add_node for nil class for the following xml - when streaming body - is expected to eq # - pkcs12 - should set the password - should set the p12 content - http_proxy - should set the address - should set the proxy user and pass when they are provided - #maintain_method_across_redirects - sets maintain_method_across_redirects to true by default - sets the maintain_method_across_redirects option to false - debug_output - stores the given stream as a default_option - stores the $stderr stream by default - format - should allow plain - should not allow funky format - does not reset parser to the default parser - sets the default parser - should allow json - should allow csv - should allow xml - should only print each format once with an exception - .query_string_normalizer - sets the query_string_normalizer option - parser - does not validate format whe custom parser is a proc - raises UnsupportedFormat when the parser cannot handle the format - should set parser options - should be able parse response with custom parser - uri_adapter - with custom URI Adaptor - should process a request with a uri instance parsed from the uri_adapter - should set the uri_adapter - should raise an ArgumentError if uri_adapter doesn't implement parse method - with Addressable::URI - handles international domains - .follow_redirects - sets follow redirects to true by default - sets the follow_redirects option to false - .normalize_base_uri - should add http if not present for non ssl requests - should not treat uri's with a port of 4430 as ssl - should not modify the parameter - should not remove https for ssl requests - should add https if not present for ssl requests - basic http authentication - should work - default params - should default to empty hash - should be able to be updated - headers - should be able to be updated - should default to empty hash - should be able to accept block as header value - overrides class headers with request headers - should pass options as argument to header block value - uses the class headers when sending a request - does not modify default_options when no arguments are passed - merges class headers with request headers - when posting file - changes content-type headers to multipart/form-data - when headers passed as symbols - converts them to string - converts default headers to string - with cookies - doesnt modify default headers - adds cookies to the headers - adds optional cookies to the optional headers - utilizes the class-level cookies - .disable_rails_query_string_format - sets the query string normalizer to HTTParty::Request::NON_RAILS_QUERY_STRING_NORMALIZER - default timeout - should raise an exception if unsupported type provided - should support floats - should support updating - should default to nil - with explicit override of automatic redirect handling - should fail with redirected PATCH - should fail with redirected HEAD - should fail with redirected POST - should fail with redirected PUT - should fail with redirected MKCOL - should fail with redirected COPY - should fail with redirected MOVE - should fail with redirected GET - should fail with redirected DELETE - should fail with redirected OPTIONS - head requests should follow redirects requesting HEAD only - should remain HEAD request across redirects, unless specified otherwise - #resend_on_redirect - sets resend_on_redirect option to false - sets resend_on_redirect to true by default - with multiple class definitions - should not run over each others options - digest http authentication - should work - #no_follow - sets the no_follow option to true - sets no_follow to false by default - base uri - should have writer - should have reader - should not modify the parameter during assignment - ssl_version - should set the ssl_version content - #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 - -HTTParty::Response - responds to predicates - responds to hash methods - responds to headers - should send missing methods to delegate - returns a comma-delimited value when multiple values exist - responds to anything parsed_response responds to - response to request - returns response headers - does raise an error about itself when invoking a method that does not exist - responds to body - responds to response - allows headers to be accessed by mixed-case names in hash notation - does raise an error about itself when using #method - responds to parsed_response - initialization - should set code as an Integer - should set code - should set body - should set the Net::HTTP Response - should set http_version - when raise_on is supplied - and response's status code is in range - throws exception - and response's status code is not in range - does not throw exception - .underscore - works with all caps - works with one capitalized word - works with titlecase - headers - always equals itself - does not equal itself when not equivalent - does equal a hash - can initialize without headers - #is_a? - is expected to respond to #is_a? with 1 argument - is expected to be truthy - is expected to be truthy - #kind_of? - is expected to be truthy - is expected to respond to #kind_of? with 1 argument - is expected to be truthy - #tap - is possible to tap into a response - semantic methods for response codes - for specific codes - responds to not_modified? - responds to payment_required? - responds to gateway_timeout? - responds to multiple_choices? - responds to not_found? - responds to created? - responds to length_required? - responds to not_acceptable? - responds to unauthorized? - responds to precondition_failed? - responds to bad_request? - responds to request_entity_too_large? - responds to switch_protocol? - responds to payload_too_large? - responds to ok? - responds to reset_content? - responds to version_not_supported? - responds to expectation_failed? - responds to requested_range_not_satisfiable? - responds to found? - responds to request_time_out? - responds to request_timeout? - responds to temporary_redirect? - responds to method_not_allowed? - responds to conflict? - responds to range_not_satisfiable? - responds to use_proxy? - responds to continue? - responds to internal_server_error? - responds to proxy_authentication_required? - responds to request_uri_too_long? - responds to bad_gateway? - responds to no_content? - responds to gone? - responds to service_unavailable? - responds to accepted? - responds to non_authoritative_information? - responds to multiple_choice? - responds to uri_too_long? - responds to forbidden? - responds to partial_content? - responds to unsupported_media_type? - responds to moved_permanently? - responds to not_implemented? - responds to gateway_time_out? - responds to see_other? - major codes - is redirection - is client error - is server error - is information - is success - marshalling - is expected to eq 200 - response is array - should be able to iterate - should equal the string response object body - should respond to array methods - should display the same as an array - #inspect - works - 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 #ancestors is expected to include StandardError - HTTParty::UnsupportedURIScheme + HTTParty::RedirectionTooDeep + #ancestors + is expected to include HTTParty::ResponseError + HTTParty::ResponseError #ancestors is expected to include HTTParty::Error HTTParty::UnsupportedFormat #ancestors is expected to include HTTParty::Error - -HTTParty::Logger - .build - raises error when formatter exists - builds :logstash style logger - defaults level to :info - builds :curl style logger - builds :custom style logger - defaults format to :apache - -HTTParty::Logger::LogstashFormatter - #format - formats a response to be compatible with Logstash - -HTTParty::ResponseFragment - access to fragment - has access to delegators + HTTParty::UnsupportedURIScheme + #ancestors + is expected to include HTTParty::Error Pending: (Failures listed here are expected and do not affect your suite's status) @@ -2093,54 +2129,54 @@ # Temporarily skipped with xit # ./spec/httparty/request_spec.rb:691 -Top 10 slowest examples (1.42 seconds, 54.7% of total time): +Top 10 slowest examples (1.51 seconds, 59.0% of total time): + HTTParty::Request SSL certificate verification should provide the certificate used by the server via peer_cert + 0.20272 seconds ./spec/httparty/ssl_spec.rb:74 HTTParty::Request SSL certificate verification should work when using ssl_ca_file with a certificate authority - 0.20367 seconds ./spec/httparty/ssl_spec.rb:37 + 0.20173 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.20206 seconds ./spec/httparty/ssl_spec.rb:33 - HTTParty::Request SSL certificate verification should provide the certificate used by the server via peer_cert - 0.2002 seconds ./spec/httparty/ssl_spec.rb:74 - HTTParty::Request SSL certificate verification should work when no trusted CA list is specified, when the verify option is set to false - 0.16809 seconds ./spec/httparty/ssl_spec.rb:19 + 0.20061 seconds ./spec/httparty/ssl_spec.rb:33 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.16403 seconds ./spec/httparty/ssl_spec.rb:29 - HTTParty::Request SSL certificate verification should fail when no trusted CA list is specified, by default - 0.10046 seconds ./spec/httparty/ssl_spec.rb:13 + 0.17461 seconds ./spec/httparty/ssl_spec.rb:29 + HTTParty::Request SSL certificate verification should fail when using ssl_ca_path and the server uses a bogus hostname + 0.16919 seconds ./spec/httparty/ssl_spec.rb:68 + HTTParty::Request SSL certificate verification should work when no trusted CA list is specified, when the verify option is set to false + 0.16826 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.10023 seconds ./spec/httparty/ssl_spec.rb:56 + 0.10152 seconds ./spec/httparty/ssl_spec.rb:56 + HTTParty::Request SSL certificate verification should fail when using ssl_ca_file and the server uses an unrecognized certificate authority + 0.0989 seconds ./spec/httparty/ssl_spec.rb:50 HTTParty::Request SSL certificate verification should fail when using ssl_ca_file and the server uses a bogus hostname - 0.09795 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.09702 seconds ./spec/httparty/ssl_spec.rb:23 - HTTParty::Request SSL certificate verification should fail when using ssl_ca_path and the server uses a bogus hostname - 0.08229 seconds ./spec/httparty/ssl_spec.rb:68 + 0.09806 seconds ./spec/httparty/ssl_spec.rb:62 + HTTParty::Request SSL certificate verification should fail when no trusted CA list is specified, by default + 0.09544 seconds ./spec/httparty/ssl_spec.rb:13 Top 10 slowest example groups: HTTParty::Request - 0.1272 seconds average (1.53 seconds / 12 examples) ./spec/httparty/ssl_spec.rb:3 + 0.13662 seconds average (1.64 seconds / 12 examples) ./spec/httparty/ssl_spec.rb:3 HTTParty::Request::Body - 0.00813 seconds average (0.08946 seconds / 11 examples) ./spec/httparty/request/body_spec.rb:6 + 0.00555 seconds average (0.06105 seconds / 11 examples) ./spec/httparty/request/body_spec.rb:6 HTTParty::ConnectionAdapter - 0.00295 seconds average (0.20658 seconds / 70 examples) ./spec/httparty/connection_adapter_spec.rb:3 + 0.00222 seconds average (0.15518 seconds / 70 examples) ./spec/httparty/connection_adapter_spec.rb:3 HTTParty::Logger::ApacheFormatter - 0.00199 seconds average (0.00399 seconds / 2 examples) ./spec/httparty/logger/apache_formatter_spec.rb:3 + 0.00187 seconds average (0.00374 seconds / 2 examples) ./spec/httparty/logger/apache_formatter_spec.rb:3 HTTParty - 0.00151 seconds average (0.17723 seconds / 117 examples) ./spec/httparty_spec.rb:3 - HTTParty::Request - 0.0015 seconds average (0.42136 seconds / 280 examples) ./spec/httparty/request_spec.rb:3 + 0.00147 seconds average (0.17195 seconds / 117 examples) ./spec/httparty_spec.rb:3 HTTParty::Logger::CurlFormatter - 0.00137 seconds average (0.01787 seconds / 13 examples) ./spec/httparty/logger/curl_formatter_spec.rb:3 + 0.00147 seconds average (0.0191 seconds / 13 examples) ./spec/httparty/logger/curl_formatter_spec.rb:3 + HTTParty::Request + 0.00118 seconds average (0.32948 seconds / 280 examples) ./spec/httparty/request_spec.rb:3 HTTParty::Decompressor - 0.00106 seconds average (0.01905 seconds / 18 examples) ./spec/httparty/decompressor_spec.rb:3 + 0.00116 seconds average (0.02081 seconds / 18 examples) ./spec/httparty/decompressor_spec.rb:3 + HTTParty::Parser + 0.00106 seconds average (0.03086 seconds / 29 examples) ./spec/httparty/parser_spec.rb:3 Net::HTTPHeader::DigestAuthenticator - 0.00095 seconds average (0.03144 seconds / 33 examples) ./spec/httparty/net_digest_auth_spec.rb:3 - HTTParty::HashConversions - 0.00092 seconds average (0.00551 seconds / 6 examples) ./spec/httparty/hash_conversions_spec.rb:3 + 0.00099 seconds average (0.03277 seconds / 33 examples) ./spec/httparty/net_digest_auth_spec.rb:3 -Finished in 2.59 seconds (files took 0.5531 seconds to load) +Finished in 2.56 seconds (files took 0.553 seconds to load) 715 examples, 0 failures, 1 pending -Randomized with seed 31731 +Randomized with seed 15937 ┌──────────────────────────────────────────────────────────────────────────────┐ @@ -2180,12 +2216,14 @@ dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: including full source code in upload I: copying local configuration +I: user script /srv/workspace/pbuilder/821157/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/821157/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/473036 and its subdirectories -I: Current time: Fri Jun 7 20:38:50 -12 2024 -I: pbuilder-time-stamp: 1717835930 +I: removing directory /srv/workspace/pbuilder/821157 and its subdirectories +I: Current time: Sat Jul 12 05:02:48 +14 2025 +I: pbuilder-time-stamp: 1752246168