Diff of the two buildlogs: -- --- b1/build.log 2024-05-06 23:48:39.469588444 +0000 +++ b2/build.log 2024-05-06 23:49:30.171430366 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Sun Jun 8 18:10:55 -12 2025 -I: pbuilder-time-stamp: 1749449455 +I: Current time: Mon Jun 9 20:11:43 +14 2025 +I: pbuilder-time-stamp: 1749449503 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/trixie-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/719170/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/3612149/tmp/hooks/D01_modify_environment starting +debug: Running on codethink01-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 Jun 9 06:11 /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/3612149/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/3612149/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='trixie' - HOME='/root' - HOST_ARCH='arm64' + DIRSTACK=() + DISTRIBUTION=trixie + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=aarch64 + HOST_ARCH=arm64 IFS=' ' - INVOCATION_ID='0ea85e77e0af4f8486a703b007991685' - 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='719170' - PS1='# ' - PS2='> ' + INVOCATION_ID=c44239d876094123b455c7612740c711 + 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=3612149 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.AArtbk0b/pbuilderrc_5Mjk --distribution trixie --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/trixie-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.AArtbk0b/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.AArtbk0b/pbuilderrc_fv2C --distribution trixie --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/trixie-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.AArtbk0b/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 codethink03-arm64 6.1.0-20-cloud-arm64 #1 SMP Debian 6.1.85-1 (2024-04-11) aarch64 GNU/Linux + Linux i-capture-the-hostname 6.1.0-20-cloud-arm64 #1 SMP Debian 6.1.85-1 (2024-04-11) aarch64 GNU/Linux I: ls -l /bin - lrwxrwxrwx 1 root root 7 Jun 5 14:47 /bin -> usr/bin -I: user script /srv/workspace/pbuilder/719170/tmp/hooks/D02_print_environment finished + lrwxrwxrwx 1 root root 7 Jun 7 17:47 /bin -> usr/bin +I: user script /srv/workspace/pbuilder/3612149/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy @@ -268,7 +300,7 @@ Get: 139 http://deb.debian.org/debian trixie/main arm64 ruby-rspec-mocks all 3.13.0c0e0m0s1-2 [81.3 kB] Get: 140 http://deb.debian.org/debian trixie/main arm64 ruby-rspec all 3.13.0c0e0m0s1-2 [5184 B] Get: 141 http://deb.debian.org/debian trixie/main arm64 ruby-webmock all 3.18.1-2 [66.2 kB] -Fetched 46.7 MB in 0s (140 MB/s) +Fetched 46.7 MB in 0s (105 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 ... 19743 files and directories currently installed.) @@ -736,8 +768,8 @@ Setting up tzdata (2024a-3) ... Current default time zone: 'Etc/UTC' -Local time is now: Mon Jun 9 06:11:15 UTC 2025. -Universal Time is now: Mon Jun 9 06:11:15 UTC 2025. +Local time is now: Mon Jun 9 06:12:05 UTC 2025. +Universal Time is now: Mon Jun 9 06:12:05 UTC 2025. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up autotools-dev (20220109.1) ... @@ -866,7 +898,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/3612149/tmp/hooks/A99_set_merged_usr starting +Not re-configuring usrmerge for trixie +I: user script /srv/workspace/pbuilder/3612149/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 @@ -898,7 +934,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/d20250608-737772-vdcmm4/gemspec +/usr/bin/ruby3.1 -S gem build --config-file /dev/null --verbose /tmp/d20250609-3636840-dris1q/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 @@ -912,7 +948,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/d20250608-737772-vdcmm4/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/d20250609-3636840-dris1q/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 @@ -980,547 +1016,154 @@ All examples were filtered out; ignoring {:focus=>true} -Randomized with seed 49605 +Randomized with seed 59172 -HTTParty::CookieHash - #to_cookie_string - should not include SameSite attribute - should not include client side only cookies - should format the key/value pairs, delimited by semi-colons - should not mutate the hash - should not include client side only cookies even when attributes use camal case - #add_cookies - with a hash - should add new key/value pairs to the hash - should overwrite any existing key - with other class - should error - with a string - should handle an empty cookie parameter - should add new key/value pairs to the hash - should handle '=' within cookie value - should overwrite any existing key - -HTTParty - parser - should be able parse response with custom parser - should set parser options - does not validate format whe custom parser is a proc - raises UnsupportedFormat when the parser cannot handle the format - uri_adapter - with custom URI Adaptor - should set the uri_adapter - should process a request with a uri instance parsed from the uri_adapter - should raise an ArgumentError if uri_adapter doesn't implement parse method - with Addressable::URI - handles international domains - with explicit override of automatic redirect handling - should fail with redirected PUT - should fail with redirected COPY - should fail with redirected MOVE - should fail with redirected OPTIONS - should fail with redirected HEAD - should fail with redirected DELETE - should fail with redirected GET - should fail with redirected PATCH - should fail with redirected POST - should fail with redirected MKCOL - http_proxy - should set the proxy user and pass when they are provided - should set the address - pem - should set the pem content - should set the password to nil if it's not provided - should set the password - .query_string_normalizer - sets the query_string_normalizer option - with multiple class definitions - should not run over each others options - .normalize_base_uri - should not modify the parameter - should add https if not present for ssl requests - should not treat uri's with a port of 4430 as ssl - should not remove https for ssl requests - should add http if not present for non ssl requests - default params - should default to empty hash - should be able to be updated - digest http authentication - should work - base uri - should have writer - should not modify the parameter during assignment - should have reader - #no_follow - sets the no_follow option to true - sets no_follow to false by default - two child classes inheriting from one parent - inherits default_options from the superclass - 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_cookies from the parent class - doesn't modify the parent's default cookies - #resend_on_redirect - sets resend_on_redirect to true by default - sets resend_on_redirect option to false - #maintain_method_across_redirects - sets maintain_method_across_redirects to true by default - sets the maintain_method_across_redirects option to false - headers - merges class headers with request headers - should be able to be updated - should be able to accept block as header value - does not modify default_options when no arguments are passed - overrides class headers with request headers - should default to empty hash - uses the class headers when sending a request - should pass options as argument to header block value - when headers passed as symbols - converts them to string - converts default headers to string - when posting file - changes content-type headers to multipart/form-data - with cookies - adds optional cookies to the optional headers - utilizes the class-level cookies - doesnt modify default headers - adds cookies to the headers - default timeout - should raise an exception if unsupported type provided - should default to nil - should support floats - should support updating - ssl_version - should set the ssl_version content - cookies - should not be in the headers by default - should allow a cookie to be specified with a one-off request - should raise an ArgumentError if passed a non-Hash - in a class with multiple methods that use different cookies - should not allow cookies used in one method to carry over into other methods - when a cookie is set at the class level - should pass the proper cookies when requested multiple times - should include that cookie in the request - should allow the class defaults to be overridden - pkcs12 - should set the password - should set the p12 content - #get - should return an empty body if stream_body option is turned on - should accept http URIs - should be able to get html - should accept https URIs - should accept webcal 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 be able to get chunked html - should be able parse response type json automatically - should be able parse response type csv automatically - should not get undefined method add_node for nil class for the following xml - when streaming body - is expected to eq # - .follow_redirects - sets follow redirects to true by default - sets the follow_redirects option to false - .disable_rails_query_string_format - sets the query string normalizer to HTTParty::Request::NON_RAILS_QUERY_STRING_NORMALIZER - #ensure_method_maintained_across_redirects - should set maintain_method_across_redirects option if unspecified - should not set maintain_method_across_redirects option if value is present - format - should not allow funky format - should allow xml - should allow csv - does not reset parser to the default parser - should allow plain - should only print each format once with an exception - sets the default parser - should allow json - debug_output - stores the given stream as a default_option - stores the $stderr stream by default - head requests should follow redirects requesting HEAD only - should remain HEAD request across redirects, unless specified otherwise - ciphers - should set the ciphers content - .raise_on - when parameters is an array - sets raise_on option - when parameters is a fixnum - sets raise_on option - connection_adapter - should set the connection_adapter - 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_options when provided - basic http authentication - should work - grand parent with inherited callback - continues running the #inherited on the parent +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 + and request's option 'base_uri' is present + logs url + and headers are not present + not log Headers + and query is present + logs Query + logs query params + and request's option 'base_uri' is not present + logs url + when request raw_body is present + not logs request body + and query is not present + not logs Query + and headers are present + logs headers keys + logs Headers -HTTParty::Error - #ancestors - is expected to include StandardError - HTTParty::RedirectionTooDeep - #ancestors - is expected to include HTTParty::ResponseError - HTTParty::DuplicateLocationHeader - #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::UnsupportedURIScheme - #ancestors - is expected to include HTTParty::Error +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 empty array - creates a params string - value is a string - creates a params string - value is an array - creates a params string - .to_params - creates a params string from a hash - nested params - creates a params string from a hash +HTTParty::Parser + #parse + returns nil for an empty body + parses ascii 8bit encoding + returns nil for a 'null' body + does not raise exceptions for bodies with invalid encodings + attempts to parse supported formats + returns nil for a body with spaces only + returns the unparsed body when the format is unsupported + ignores utf-8 bom + parses frozen strings + returns nil for a nil body + .supports_format? + returns false for an unsupported format + returns true for a supported format + #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 + #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 + .format_from_mimetype + returns a symbol representing the format mimetype + returns nil when the mimetype is not supported + .call + generates an HTTParty::Parser instance with the given body and format + calls #parse on the parser + .formats + returns the SupportedFormats constant + returns the SupportedFormats constant for subclasses + parsers + parses json with JSON + parses plain text by simply returning the body + parses xml with MultiXml + parses html by simply returning the body + parses csv with CSV + .SupportedFormats + returns a hash HTTParty::Decompressor - .SupportedEncodings - returns a hash #decompress - 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 "zstd" - when zstd-ruby gem not included - behaves like returns nil - is expected to be nil - when zstd-ruby included - is expected to eq "foobar" - when zstd raises error - is expected to eq nil when encoding is "compress" + 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 raises error is expected to eq nil - when compress-lzw included - is expected to eq "foobar" when ruby-lzws included is expected to eq "foobar" when encoding is nil 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 "none" behaves like returns the body is expected to eq "body" + when encoding is "identity" + behaves like returns the body + is expected to eq "body" + when encoding is unsupported + behaves like returns nil + is expected to be nil + when body is blank + is expected to eq " " when encoding is "br" + when brotli included + is expected to eq "foobar" when brotli raises error is expected to eq nil when brotli gem not included behaves like returns nil is expected to be nil - when brotli included - is expected to eq "foobar" - when encoding is "identity" + when encoding is blank behaves like returns the body is expected to eq "body" - when body is blank - is expected to eq " " - -HTTParty::Request::Body - #call - when params is string - is expected to eq "name=Bob%20Jones" - when params is hash - is expected to eq "people%5B%5D=Bob%20Jones&people%5B%5D=Mike%20Smith" - when params has file - is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[avatar]\";...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" - is expected not to change `file.pos` - 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" - 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" - #multipart? - when params does not respond to to_hash - is expected to equal false - when params responds to to_hash - when it contains file - is expected to equal true - when force_multipart is true - is expected to equal true - when it does not contain a file - is expected to eq false - -HTTParty::Parser - .formats - returns the SupportedFormats constant - returns the SupportedFormats constant for subclasses - .SupportedFormats + when encoding is "zstd" + when zstd raises error + is expected to eq nil + when zstd-ruby gem not included + behaves like returns nil + is expected to be nil + when zstd-ruby included + is expected to eq "foobar" + when body is nil + behaves like returns nil + is expected to be nil + .SupportedEncodings returns a hash - .format_from_mimetype - returns a symbol representing the format mimetype - returns nil when the mimetype is not supported - .supported_formats - returns a unique set of supported formats represented by symbols - #parse - returns nil for an empty body - ignores utf-8 bom - returns the unparsed body when the format is unsupported - parses frozen strings - parses ascii 8bit encoding - returns nil for a 'null' body - does not raise exceptions for bodies with invalid encodings - returns nil for a body with spaces only - returns nil for a nil body - attempts to parse supported formats - #supports_format? - utilizes the class method to determine if the format is supported - parsers - parses plain text by simply returning the body - parses xml with MultiXml - parses csv with CSV - parses html by simply returning the body - parses json with JSON - #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 - .supports_format? - returns false for an unsupported format - returns true for a supported format - .call - generates an HTTParty::Parser instance with the given body and format - calls #parse on the parser -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::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 - 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: 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 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 - 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 - 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 no trusted CA list is specified, with a bogus hostname, by default - should work when no trusted CA list is specified, even with a bogus hostname, when the verify option is set to true - should provide the certificate used by the server via peer_cert -# 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 +HTTParty::CookieHash + #to_cookie_string + should format the key/value pairs, delimited by semi-colons + should not include client side only cookies + should not mutate the hash + should not include SameSite attribute + should not include client side only cookies even when attributes use camal case + #add_cookies + with a string + should add new key/value pairs to the hash + should overwrite any existing key + should handle an empty cookie parameter + should handle '=' within cookie value + with a hash + should add new key/value pairs to the hash + should overwrite any existing key + with other class + should error HTTParty::ResponseFragment - access to fragment has access to delegators - -HTTParty::Logger::LogstashFormatter - #format - formats a response to be compatible with Logstash - -HTTParty::HeadersProcessor - when only request specific headers are set - returns stringified request specific headers - when headers are not set at all - returns empty hash - when headers are dynamic - returns processed global and request specific headers - 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 - -HTTParty::Logger::CurlFormatter - #format - formats a response in a style that resembles a -v curl - when response is logged - logs body - logs http version and response code - logs headers - when request is logged - and query is not present - not logs Query - and request's option 'base_uri' is present - logs url - and query is present - logs Query - logs query params - and headers are not present - not log Headers - and headers are present - logs Headers - logs headers keys - and request's option 'base_uri' is not present - logs url - when request raw_body is present - not logs request body - -HTTParty::Response - returns a comma-delimited value when multiple values exist - response to request - responds to predicates - does raise an error about itself when invoking a method that does not exist - responds to body - responds to response - returns response headers - responds to anything parsed_response responds to - responds to headers - allows headers to be accessed by mixed-case names in hash notation - should send missing methods to delegate - responds to parsed_response - responds to hash methods - does raise an error about itself when using #method - initialization - should set body - should set the Net::HTTP Response - should set code as an Integer - should set code - 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 - semantic methods for response codes - for specific codes - responds to gateway_timeout? - responds to gone? - responds to expectation_failed? - responds to temporary_redirect? - responds to not_acceptable? - responds to partial_content? - responds to service_unavailable? - responds to use_proxy? - responds to uri_too_long? - responds to internal_server_error? - responds to forbidden? - responds to method_not_allowed? - responds to unauthorized? - responds to continue? - responds to not_found? - responds to requested_range_not_satisfiable? - responds to not_implemented? - responds to non_authoritative_information? - responds to version_not_supported? - responds to found? - responds to conflict? - responds to request_entity_too_large? - responds to see_other? - responds to created? - responds to payment_required? - responds to request_uri_too_long? - responds to unsupported_media_type? - responds to range_not_satisfiable? - responds to not_modified? - responds to accepted? - responds to multiple_choice? - responds to payload_too_large? - responds to reset_content? - responds to moved_permanently? - responds to ok? - responds to request_timeout? - responds to switch_protocol? - responds to bad_gateway? - responds to multiple_choices? - responds to bad_request? - responds to length_required? - responds to precondition_failed? - responds to gateway_time_out? - responds to proxy_authentication_required? - responds to no_content? - responds to request_time_out? - major codes - is information - is client error - is redirection - is server error - is success - #tap - is possible to tap into a response - marshalling - is expected to eq 200 - #kind_of? - is expected to be truthy - is expected to be truthy - is expected to respond to #kind_of? with 1 argument - #is_a? - is expected to be truthy - is expected to be truthy - is expected to respond to #is_a? with 1 argument - #inspect - works - headers - does equal a hash - does not equal itself when not equivalent - always equals itself - can initialize without headers - 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 - .underscore - works with titlecase - works with one capitalized word - works with all caps + access to fragment HTTParty::Request [DEPRECATION] HTTParty will no longer override `response#nil?`. This functionality will be removed in future versions. Please, add explicit check `response.body.nil? || response.body.empty?`. For more info refer to: https://github.com/jnunemaker/httparty/issues/568 @@ -1529,359 +1172,248 @@ /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 should not fail for missing mime type - ::NON_RAILS_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 - options - should normalize base uri when specified as request option - should use basic auth when configured - should use body_stream when configured - digest_auth - should maintain cookies returned from a 401 response - should not send credentials more than once - should not be used when configured and the response is 200 - should merge cookies from request and a 401 response - should be used when configured and the response is 401 + #format + request yet to be made + returns format option + returns nil format + request has been made + returns format option + returns the content-type from the last response when the option is not set + #format_from_mimetype + should handle application/vnd.api+json + should handle application/json + returns nil for an unrecognized mimetype + should handle application/csv + should handle application/javascript + should handle text/csv + should handle text/comma-separated-values + returns nil when using a default parser + should handle text/xml + should handle text/json + should handle application/hal+json + should handle application/xml + should handle text/javascript parsing responses - should process utf-16 charset with big endian bom correctly - should assume utf-16 little endian if options has been chosen - should handle xml automatically - should process response with a nil body - should handle csv automatically - should handle utf-8 bom in xml - should handle utf-8 bom in json should perform no encoding if the charset is not available 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 json + should handle utf-8 bom in xml + should handle csv automatically + should assume utf-16 little endian if options has been chosen + should process utf-16 charset with big endian bom correctly + should process response with a nil body should include any HTTP headers in the returned response - when assume_utf16_is_big_endian is true - processes stubbed frozen body correctly - should process utf-16 charset with little endian bom correctly + should handle json automatically with non-200 responses - should return a valid object for 5xx response should return a valid object for 4xx response parses response lazily so codes can be checked prior + should return a valid object for 5xx response 3xx responses - handles multiple redirects and relative location headers on different hosts returns the HTTParty::Response when the 300 does not contain a location header - raises an error if redirect has duplicate location header [DEPRECATION] HTTParty will no longer override `response#nil?`. This functionality will be removed in future versions. Please, add explicit check `response.body.nil? || response.body.empty?`. For more info refer to: https://github.com/jnunemaker/httparty/issues/568 /usr/share/rubygems-integration/all/gems/rspec-expectations-3.13.0/lib/rspec/matchers/built_in/be.rb:69:in `match' returns a valid object for 304 not modified - redirects if a 300 contains a relative location header redirects if a 300 contains a location header redirects including port + handles multiple redirects and relative location headers on different hosts calls block given to perform with each redirect (PENDING: Temporarily skipped with xit) + raises an error if redirect has duplicate location header + redirects if a 300 contains a relative location header + decompression + should not decompress the body if the :skip_decompression option is set + should decompress the body and remove the Content-Encoding header + should remove the Content-Encoding header if uncompressed + should not decompress unrecognized Content-Encoding when body has ascii-8bit encoding - processes quoted charset in content type properly processes charset in content type properly if it has a different case + processes quoted charset in content type properly processes charset in content type properly when stubed body is frozen processes frozen body correctly - decompression - should not decompress unrecognized Content-Encoding - 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 - #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 not send Authorization header when redirecting to a different host - should send Authorization header when redirecting to a different port on the same host - #format_from_mimetype - returns nil for an unrecognized mimetype - should handle text/comma-separated-values - should handle application/hal+json - should handle application/xml - returns nil when using a default parser - should handle application/vnd.api+json - should handle text/json - should handle application/json - should handle application/javascript - should handle text/xml - should handle application/csv - should handle text/csv - should handle text/javascript - with POST http method - should raise argument error if query is not a hash - a request that 301 redirects + 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 303 redirects once should be handled by MKCOL transparently - should be handled by GET transparently + should be handled by OPTIONS transparently + should be handled by HEAD transparently + should be handled by POST transparently + should be handled by PATCH transparently + should be handled by COPY transparently + should keep cookies between redirects + should handle multiple Set-Cookie headers between redirects + should be handled by DELETE transparently should be handled by MOVE 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 UNLOCK transparently + should update cookies with redirects should make resulting request a get request if it not already - should be handled by COPY transparently + should make resulting request a get request if options[:maintain_method_across_redirects] is false should be handled by PUT transparently + should not make resulting request a get request if options[:maintain_method_across_redirects] and options[:resend_on_redirect] is true + should be handled by GET transparently should log the redirection - should be handled by HEAD transparently - should update cookies with redirects should keep track of cookies between redirects - should be handled by DELETE transparently - should be handled by OPTIONS transparently - should be handled by UNLOCK transparently - should keep cookies between redirects - should be handled by PATCH transparently should be handled by LOCK transparently - should be handled by POST transparently - should handle multiple Set-Cookie headers between redirects - should not make resulting request a get request if options[:maintain_method_across_redirects] is true infinitely should raise an exception - http - should get a connection from the connection_adapter - a request that 302 redirects + a request that 307 redirects once should log the redirection - should be handled by DELETE transparently - should be handled by PATCH transparently - should be handled by MOVE transparently + should maintain method in resulting request if options[:maintain_method_across_redirects] is false should be handled by LOCK 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 keep cookies between redirects - should be handled by HEAD transparently - should keep track of cookies between redirects should be handled by OPTIONS transparently + should keep track of cookies between redirects should be handled by UNLOCK transparently - should make resulting request a get request if it not already - should be handled by MKCOL transparently should be handled by PUT transparently + should maintain method in resulting request should be handled by POST transparently + should be handled by GET transparently + should keep cookies between redirects should update cookies with redirects + should handle multiple Set-Cookie headers between redirects + should be handled by DELETE transparently should be handled by COPY transparently - should be handled by GET transparently + should be handled by HEAD transparently + should be handled by PATCH transparently + should be handled by MOVE transparently + should maintain method in resulting request if options[:maintain_method_across_redirects] is true + should be handled by MKCOL transparently infinitely should raise an exception - ::JSON_API_QUERY_STRING_NORMALIZER - doesn't modify strings - when the query is a hash - correctly handles nil values - when the query is an array - URI encodes array values - doesn't include brackets - #uri - query strings - respects the query string normalization proc - does not add an empty query string when default_params are blank - does not append an ampersand when queries are embedded in paths - does not duplicate query string parameters when uri is called twice - when representing an array - returns a Rails style query string - redirects - returns correct path when the server sets the location header to a full uri - returns correct path when the server sets the location header to a network-path reference - returns correct path when the server sets the location header to a filename - location header is an absolute path - returns correct path when location has leading slash - returns the correct path when location has no leading slash - a request that 300 redirects + a request that returns 304 + should report 304 with a MOVE request + should report 304 with a MKCOL request + should be handled by UNLOCK transparently + should report 304 with a PUT request + should report 304 with a DELETE request + should not log the redirection + should report 304 with a PATCH request + should report 304 with a OPTIONS request + should report 304 with a POST request + should report 304 with a COPY request + should report 304 with a GET request + should report 304 with a HEAD request + should be handled by LOCK transparently + options + should use body_stream when configured + should use basic auth when configured + should normalize base uri when specified as request option + digest_auth + should not be used when configured and the response is 200 + should be used when configured and the response is 401 + should maintain cookies returned from a 401 response + should merge cookies from request and a 401 response + should not send credentials more than once + a request that 308 redirects infinitely should raise an exception once - should log the redirection - should be handled by PATCH transparently - should make resulting request a get request if it not already - should keep cookies between redirects - should be handled by COPY transparently - should be handled by LOCK transparently - should be handled by POST transparently - should be handled by UNLOCK transparently - should be handled by GET transparently should keep track of cookies between redirects - should be handled by MOVE transparently - should be handled by DELETE transparently should be handled by HEAD transparently + should keep cookies between redirects + should maintain method in resulting request should update cookies with redirects - should handle multiple Set-Cookie headers between redirects - should be handled by PUT transparently - should be handled by MKCOL transparently - should not make resulting request a get request if options[:maintain_method_across_redirects] is true - should be handled by OPTIONS transparently - #format - request has been made - returns the content-type from the last response when the option is not set - returns format option - request yet to be made - returns format option - returns nil format - a request that 305 redirects - once - should keep track of cookies between redirects - should be handled by GET transparently should be handled by MOVE transparently - should be handled by HEAD transparently - should log the redirection - should keep cookies between redirects - should be handled by COPY transparently + should maintain method in resulting request if options[:maintain_method_across_redirects] is false should be handled by UNLOCK transparently + should be handled by GET transparently + should be handled by DELETE transparently should be handled by PATCH transparently - should be handled by LOCK transparently should be handled by OPTIONS transparently - should be handled by DELETE transparently + should maintain method in resulting request if options[:maintain_method_across_redirects] is true should handle multiple Set-Cookie headers between redirects + should be handled by LOCK transparently + should log the redirection should be handled by POST transparently - should update cookies with redirects - should be handled by MKCOL transparently - should make resulting request a get request if it not already - should not make resulting request a get request if options[:maintain_method_across_redirects] is true should be handled by PUT transparently + should be handled by COPY transparently + should be handled by MKCOL transparently + a request that 305 redirects infinitely should raise an exception - a request that 308 redirects once - should be handled by UNLOCK transparently - should log the redirection + should be handled by PATCH transparently + should be handled by OPTIONS transparently should be handled by HEAD transparently + should make resulting request a get request if it not already + should be handled by LOCK transparently + should be handled by COPY transparently + should log the redirection + should not make resulting request a get request if options[:maintain_method_across_redirects] is true should be handled by PUT transparently should keep track of cookies between redirects - should be handled by GET transparently - should maintain method in resulting request if options[:maintain_method_across_redirects] is true - should be handled by DELETE transparently - should be handled by MOVE transparently + should handle multiple Set-Cookie headers between redirects should keep cookies between redirects - should be handled by LOCK transparently - should be handled by POST transparently should update cookies with redirects - should be handled by COPY transparently - should be handled by OPTIONS transparently + should be handled by MOVE transparently + should be handled by UNLOCK transparently should be handled by MKCOL transparently - should maintain method in resulting request - should maintain method in resulting request if options[:maintain_method_across_redirects] is false - should handle multiple Set-Cookie headers between redirects - should be handled by PATCH transparently - infinitely - should raise an exception + should be handled by POST transparently + should be handled by GET transparently + should be handled by DELETE transparently + #send_authorization_header? + basic_auth + should not send Authorization header when redirecting to a different host + should send Authorization header when redirecting to a different port on the same host + should send Authorization header when redirecting to the same host + should send Authorization header when redirecting to a relative path + ::JSON_API_QUERY_STRING_NORMALIZER + doesn't modify strings + when the query is a hash + correctly handles nil values + when the query is an array + URI encodes array values + doesn't include brackets marshalling properly marshals the request object - argument validation - should raise argument error if basic_auth is not a hash - should raise argument error if digest_auth is not a hash - should raise argument error if options method is not http accepted method - should raise argument error if http method is post and query is not hash - should raise argument error if basic_auth and digest_auth are both present - should raise RedirectionTooDeep error if limit is negative - should raise argument error if headers 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= - a request that returns 304 - should not log the redirection - should report 304 with a COPY request - should report 304 with a HEAD request - should be handled by UNLOCK transparently - should report 304 with a MKCOL request - should report 304 with a POST request - should be handled by LOCK transparently - should report 304 with a GET request - should report 304 with a OPTIONS request - should report 304 with a PATCH request - should report 304 with a DELETE request - should report 304 with a PUT request - should report 304 with a MOVE request - a request that 307 redirects + a request that 300 redirects infinitely should raise an exception once - should be handled by PATCH transparently should log the redirection - should be handled by MKCOL transparently - should maintain method in resulting request if options[:maintain_method_across_redirects] is false - should be handled by LOCK transparently - should handle multiple Set-Cookie headers between redirects should be handled by HEAD transparently should be handled by GET transparently - should be handled by DELETE transparently - should keep track of cookies between redirects - should maintain method in resulting request should be handled by MOVE transparently - should be handled by POST transparently - should maintain method in resulting request if options[:maintain_method_across_redirects] is true + should keep track of cookies between redirects + should be handled by DELETE transparently + should not make resulting request a get request if options[:maintain_method_across_redirects] is true should update cookies with redirects - should be handled by OPTIONS transparently - should keep cookies between redirects - should be handled by COPY transparently - should be handled by PUT transparently should be handled by UNLOCK transparently - initialization - sets parser to HTTParty::Parser - sets connection_adapter to HTTParty::ConnectionAdapter - sets parser to the optional parser - sets connection_adapter to the optional connection_adapter - when basic authentication credentials provided in uri - when basic auth options wasn't set explicitly - sets basic auth from uri - when basic auth options was set explicitly - uses basic auth from url anyway - 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 - a request that 303 redirects - once - should keep track of cookies between redirects should be handled by COPY transparently - should be handled by UNLOCK 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 PATCH transparently - should be handled by POST transparently - should be handled by DELETE transparently + should keep cookies between redirects + should be handled by OPTIONS transparently should make resulting request a get request if it not already should be handled by PUT transparently - should keep cookies between redirects - should update cookies with redirects should be handled by LOCK transparently - should be handled by MOVE transparently - should be handled by MKCOL transparently - should be handled by OPTIONS transparently - should log the redirection - should make resulting request a get request if options[:maintain_method_across_redirects] is false - should not make resulting request a get request if options[:maintain_method_across_redirects] and options[:resend_on_redirect] is true - should be handled by HEAD transparently - should be handled by GET transparently + should be handled by POST transparently should handle multiple Set-Cookie headers between redirects - infinitely - should raise an exception + should be handled by PATCH transparently + should be handled by MKCOL transparently + #uri + query strings + does not add an empty query string when default_params are blank + does not append an ampersand when queries are embedded in paths + respects the query string normalization proc + does not duplicate query string parameters when uri is called twice + when representing an array + returns a Rails style query string + redirects + 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 full uri + 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 Net::HTTP decompression - with skip_decompression false (default) + with skip_decompression true 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 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 enables Net::HTTP decompression - is expected to eq true - behaves like sets custom Accept-Encoding - is expected to eq "custom" - 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 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 skip_decompression true + behaves like disables Net::HTTP decompression + is expected to eq false with Accept-Encoding and other headers specified behaves like sets custom Accept-Encoding is expected to eq "custom" @@ -1902,210 +1434,714 @@ 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 skip_decompression false (default) + with Accept-Encoding and other headers specified + behaves like enables Net::HTTP decompression + is expected to eq true + behaves like sets custom Accept-Encoding + is expected to eq "custom" + 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 other 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" - -Net::HTTPHeader::DigestAuthenticator - without a cookie value in the response header - should set empty cookie header array - with algorithm specified - should recognise algorithm was specified - should set the algorithm header - with an opaque value in the response header - should set opaque - with specified quality of protection (qop) - should set digest-uri - should set nonce-count - should set response - should set username - should set qop - should set cnonce - should set prefix - when quality of protection (qop) is unquoted - should still set qop - with unspecified quality of protection (qop) - should set prefix - should not set qop - should not set cnonce - should not set nonce-count - should set username - should set digest-uri - should set response - with http basic auth response when net digest auth expected - should not fail - Net::HTTPHeader#digest_auth - should set the authorization header - with a cookie value in the response header - should set cookie header - without an opaque valid in the response header - should not set opaque - 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 cnonce - should set qop - should set nonce-count - should set prefix - should set response - should set digest-uri - should set username + behaves like enables Net::HTTP decompression + is expected to eq true + 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" + a request that 302 redirects + infinitely + should raise an exception + once + should be handled by COPY transparently + should make resulting request a get request if it not already + should keep cookies between redirects + should be handled by OPTIONS transparently + should be handled by HEAD transparently + should be handled by DELETE transparently + should be handled by LOCK transparently + should update cookies with redirects + should be handled by GET transparently + should be handled by MKCOL transparently + should be handled by POST transparently + should keep track of cookies between redirects + should log the redirection + should be handled by UNLOCK transparently + should be handled by PUT transparently + 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 handle multiple Set-Cookie headers between redirects + http + should get a connection from the connection_adapter + argument validation + should raise argument error if http method is post and query is not hash + should raise argument error if digest_auth is not a hash + should raise argument error if basic_auth and digest_auth are both present + should raise argument error if options method is not http accepted method + should raise argument error if headers is not a hash + should raise RedirectionTooDeep error if limit is negative + should raise argument error if basic_auth is not a hash + a request that 301 redirects + once + should update cookies with redirects + should be handled by MKCOL transparently + should not make resulting request a get request if options[:maintain_method_across_redirects] is true + should keep track of cookies between redirects + should be handled by COPY transparently + should log the redirection + should be handled by OPTIONS transparently + should be handled by HEAD transparently + should be handled by DELETE transparently + should be handled by GET transparently + should be handled by PATCH transparently + should be handled by MOVE transparently + should handle multiple Set-Cookie headers between redirects + should be handled by LOCK transparently + should make resulting request a get request if it not already + should be handled by PUT transparently + should be handled by UNLOCK transparently + should be handled by POST transparently + should keep cookies between redirects + infinitely + should raise an exception + #setup_raw_request + 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= + when query_string_normalizer is set + sets the body to the return value of the proc + with POST http method + should raise argument error if query is not a hash + ::NON_RAILS_QUERY_STRING_NORMALIZER + doesn't modify strings + when the query is a hash + correctly handles nil values + when the query is an array + URI encodes array values + doesn't include brackets + initialization + sets connection_adapter to the optional connection_adapter + sets parser to HTTParty::Parser + sets parser to the optional parser + sets connection_adapter to HTTParty::ConnectionAdapter + 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 + 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 HTTParty::ConnectionAdapter - .call - calls #connection on the connection adapter - generates an HTTParty::ConnectionAdapter instance with the given uri and options initialization - raises an ArgumentError if the uri is a String - raises an ArgumentError if the uri is nil takes a URI as input - sets the uri sets the options + raises an ArgumentError if the uri is a String also accepts an optional options hash + sets the uri + raises an ArgumentError if the uri is nil #connection the resulting connection is expected to be an instance of Net::HTTP - 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 set and read_timeout is set to 6 seconds + when providing proxy address and port + is expected to be a proxy + as well as proxy user and password + #proxy_user + is expected to eq "user" + #proxy_pass + is expected to eq "pass" + #proxy_address + is expected to eq "1.2.3.4" + #proxy_port + is expected to eq 8080 + 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 debug_output + is set to $stderr + has debug output set + is not provided + does not set_debug_output + when timeout is not set + doesn't set the timeout + specifying ciphers + should set the ciphers on the connection + when timeout is set and read_timeout is set to 6 seconds + should override the timeout option + #read_timeout is expected to eq 6 #open_timeout is expected to eq 5 + #write_timeout + is expected to eq 5 when 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 timeout is set and open_timeout is set to 7 seconds - should override the timeout option + when timeout is not set and read_timeout is set to 6 seconds + should not set the write_timeout + should not set the open_timeout #read_timeout - is expected to eq 5 - #write_timeout - is expected to eq 5 - #open_timeout - is expected to eq 7 - using port 80 - is expected not to use ssl - when timeout is not set and write_timeout is set to 8 seconds - should not set the open timeout - should not set the read timeout + is expected to eq 6 + 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 dealing with ssl - uses the system cert_store, by default - is expected to use cert store # - https scheme with default port - is expected to use ssl - when ssl version is set - sets ssl version - should use the specified cert store, when one is given - is expected to use cert store # - https scheme with non-standard port - is expected to use ssl - using port 443 for ssl - is expected to use ssl - when setting timeout - to 5 seconds - #write_timeout - is expected to eq 5 - #open_timeout - is expected to eq 5 - #read_timeout - is expected to eq 5 - and timeout is a string - doesn't set the timeout - when timeout is not set - doesn't set the timeout - when setting max_retries - to 0 times - #max_retries - is expected to eq 0 - and max_retries is a string - doesn't set the max_retries - to 5 times - #max_retries - is expected to eq 5 - when max_retries is not set - doesn't set the max_retries when dealing with IPv6 strips brackets from the address - when providing PKCS12 certificates + when providing PEM certificates when scheme is https - uses the provided P12 certificate + uses the provided PEM certificate will verify the certificate when options include verify_peer=false should not verify the certificate when options include verify=false should not verify the certificate when scheme is not https - has no PKCS12 certificate - when providing PEM certificates - when scheme is not https has no PEM certificate + when setting max_retries + to 5 times + #max_retries + is expected to eq 5 + to 0 times + #max_retries + is expected to eq 0 + and max_retries is a string + doesn't set the max_retries + 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 + when providing PKCS12 certificates when scheme is https will verify the certificate - uses the provided PEM certificate + uses the provided P12 certificate when options include verify=false should not verify the certificate when options include verify_peer=false should not verify the certificate - specifying ciphers - should set the ciphers on the connection + when scheme is not https + has no PKCS12 certificate + using port 80 + is expected not to use ssl when not providing a proxy address does not pass any proxy parameters to the connection - 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 timeout is set and write_timeout is set to 8 seconds - should override the timeout option - #write_timeout - is expected to eq 8 + 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 setting timeout + and timeout is a string + doesn't set the timeout + to 5 seconds + #open_timeout + is expected to eq 5 + #write_timeout + is expected to eq 5 + #read_timeout + is expected to eq 5 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 debug_output - is set to $stderr - has debug output set - is not provided - does not set_debug_output - when providing proxy address and port - is expected to be a proxy - as well as proxy user and password - #proxy_user - is expected to eq "user" - #proxy_pass - is expected to eq "pass" - #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_port - is expected to eq 12345 - #local_host - is expected to eq "127.0.0.1" + when timeout is not set and write_timeout is set to 8 seconds + should not set the read timeout + should not set the open timeout + #write_timeout + is expected to eq 8 + when dealing with ssl + https scheme with default port + is expected to use ssl + using port 443 for ssl + is expected to use ssl + uses the system cert_store, by default + is expected to use cert store # + when ssl version is set + sets ssl version + should use the specified cert store, when one is given + is expected to use cert store # + https scheme with non-standard port + is expected to use ssl + when max_retries is not set + doesn't set the max_retries + .call + generates an HTTParty::ConnectionAdapter instance with the given uri and options + calls #connection on the connection adapter + +HTTParty::HashConversions + .to_params + creates a params string from a hash + nested params + creates a params string from a hash + .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 + +HTTParty::Response + responds to body + responds to predicates + responds to headers + responds to anything parsed_response responds to + responds to parsed_response + does raise an error about itself when invoking a method that does not exist + should send missing methods to delegate + responds to response + does raise an error about itself when using #method + returns a comma-delimited value when multiple values exist + responds to hash methods + allows headers to be accessed by mixed-case names in hash notation + returns response headers + response to request + #kind_of? + is expected to be truthy + is expected to respond to #kind_of? with 1 argument + is expected to be truthy + response is array + should be able to iterate + should respond to array methods + should display the same as an array + should equal the string response object body + initialization + should set body + should set the Net::HTTP Response + should set code as an Integer + should set code + should set http_version + when raise_on is supplied + and response's status code is not in range + does not throw exception + and response's status code is in range + throws exception + headers + does equal a hash + can initialize without headers + does not equal itself when not equivalent + always equals itself + #tap + is possible to tap into a response + .underscore + works with one capitalized word + works with all caps + works with titlecase + semantic methods for response codes + major codes + is client error + is success + is server error + is information + is redirection + for specific codes + responds to unsupported_media_type? + responds to version_not_supported? + responds to conflict? + responds to uri_too_long? + responds to gateway_time_out? + responds to service_unavailable? + responds to reset_content? + responds to no_content? + responds to partial_content? + responds to bad_gateway? + responds to see_other? + responds to request_entity_too_large? + responds to request_uri_too_long? + responds to range_not_satisfiable? + responds to multiple_choices? + responds to multiple_choice? + responds to use_proxy? + responds to moved_permanently? + responds to precondition_failed? + responds to length_required? + responds to internal_server_error? + responds to payload_too_large? + responds to gateway_timeout? + responds to payment_required? + responds to bad_request? + responds to unauthorized? + responds to request_timeout? + responds to expectation_failed? + responds to not_implemented? + responds to ok? + responds to temporary_redirect? + responds to not_modified? + responds to continue? + responds to requested_range_not_satisfiable? + responds to accepted? + responds to not_acceptable? + responds to request_time_out? + responds to proxy_authentication_required? + responds to forbidden? + responds to gone? + responds to method_not_allowed? + responds to created? + responds to not_found? + responds to found? + responds to switch_protocol? + responds to non_authoritative_information? + #inspect + works + marshalling + is expected to eq 200 + #is_a? + is expected to be truthy + is expected to be truthy + is expected to respond to #is_a? with 1 argument + +HTTParty::Request::Body + #multipart? + 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 + when params does not respond to to_hash + is expected to equal false + #call + when params is hash + is expected to eq "people%5B%5D=Bob%20Jones&people%5B%5D=Mike%20Smith" + when params has file + is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[avatar]\";...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" + is expected not to change `file.pos` + 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 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" + when params is string + is expected to eq "name=Bob%20Jones" + +HTTParty::Error + HTTParty::UnsupportedURIScheme + #ancestors + is expected to include HTTParty::Error + HTTParty::ResponseError + #ancestors + is expected to include HTTParty::Error + #ancestors + is expected to include StandardError + HTTParty::RedirectionTooDeep + #ancestors + is expected to include HTTParty::ResponseError + HTTParty::DuplicateLocationHeader + #ancestors + is expected to include HTTParty::ResponseError + HTTParty::UnsupportedFormat + #ancestors + is expected to include HTTParty::Error + +Net::HTTPHeader::DigestAuthenticator + without a cookie value in the response header + should set empty cookie header array + with unspecified quality of protection (qop) + should not set qop + should set prefix + should not set cnonce + should set username + should set response + should set digest-uri + should not set nonce-count + with a cookie value in the response header + should set cookie header + with multiple authenticate headers + should set qop + should set nonce-count + should set prefix + should set username + should set cnonce + should set response + should set digest-uri + Net::HTTPHeader#digest_auth + should set the authorization header + 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 http basic auth response when net digest auth expected + should not fail + without an opaque valid in the response header + should not set opaque + with md5-sess algorithm specified + should set the algorithm header + should set response using md5-sess algorithm + should recognise algorithm was specified + with an opaque value in the response header + should set opaque + with specified quality of protection (qop) + should set digest-uri + should set cnonce + should set nonce-count + should set prefix + should set username + should set response + should set qop + +HTTParty::Request + SSL certificate verification + 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 an unrecognized 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 a bogus hostname + should provide the certificate used by the server via peer_cert + 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: 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 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, by default + should work when no trusted CA list is specified, even with a bogus hostname, when the verify option is set to true + should 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, with a bogus hostname, by default + +HTTParty + 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 + grand parent with inherited callback + continues running the #inherited on the parent + .raise_on + when parameters is an array + sets raise_on option + when parameters is a fixnum + 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 + http_proxy + should set the address + should set the proxy user and pass when they are provided + pem + should set the pem content + should set the password to nil if it's not provided + should set the password + uri_adapter + with custom URI Adaptor + should set the uri_adapter + should process a request with a uri instance parsed from the uri_adapter + should raise an ArgumentError if uri_adapter doesn't implement parse method + with Addressable::URI + handles international domains + basic http authentication + should work + two child classes inheriting from one parent + does not modify each others inherited attributes + inherits default_options from the superclass + inherits default_cookies from the parent class + doesn't modify hashes in the parent's default options + doesn't modify the parent's default options + doesn't modify the parent's default cookies + works with lambda values + should dup the proc on the child class + #no_follow + sets the no_follow option to true + sets no_follow to false by default + parser + raises UnsupportedFormat when the parser cannot handle the format + does not validate format whe custom parser is a proc + should be able parse response with custom parser + should set parser options + digest http authentication + should work + debug_output + stores the $stderr stream by default + stores the given stream as a default_option + #maintain_method_across_redirects + sets the maintain_method_across_redirects option to false + sets maintain_method_across_redirects to true by default + .normalize_base_uri + should add https if not present for ssl requests + should not modify the parameter + should add http if not present for non ssl requests + should not treat uri's with a port of 4430 as ssl + should not remove https for ssl requests + headers + overrides class headers with request headers + does not modify default_options when no arguments are passed + should default to empty hash + should be able to be updated + should pass options as argument to header block value + should be able to accept block as header value + uses the class headers when sending a request + 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 + utilizes the class-level cookies + adds cookies to the headers + doesnt modify default headers + adds optional cookies to the optional headers + base uri + should not modify the parameter during assignment + should have reader + should have writer + default timeout + should support updating + should default to nil + should support floats + should raise an exception if unsupported type provided + pkcs12 + should set the password + should set the p12 content + #resend_on_redirect + sets resend_on_redirect to true by default + sets resend_on_redirect option to false + with explicit override of automatic redirect handling + should fail with redirected OPTIONS + should fail with redirected DELETE + should fail with redirected PATCH + should fail with redirected POST + should fail with redirected MOVE + should fail with redirected PUT + should fail with redirected COPY + should fail with redirected HEAD + should fail with redirected GET + should fail with redirected MKCOL + connection_adapter + 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 + should set the connection_adapter_options when provided + .query_string_normalizer + sets the query_string_normalizer option + format + should only print each format once with an exception + does not reset parser to the default parser + should allow xml + should allow plain + sets the default parser + should allow json + should not allow funky format + should allow csv + default params + should default to empty hash + should be able to be updated + ciphers + should set the ciphers content + .disable_rails_query_string_format + sets the query string normalizer to HTTParty::Request::NON_RAILS_QUERY_STRING_NORMALIZER + #get + should return an empty body if stream_body option is turned on + should be able to get chunked html + should be able parse response type xml automatically + should be able parse response type csv automatically + should be able parse response type json 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 accept http URIs + should not get undefined method add_node for nil class for the following xml + should accept webcal URIs + should be able to get html + should raise an InvalidURIError on URIs that can't be parsed at all + should accept https URIs + when streaming body + is expected to eq # + with multiple class definitions + should not run over each others options + cookies + should not be in the headers by default + should allow a cookie to be specified with a one-off request + should raise an ArgumentError if passed a non-Hash + in a class with multiple methods that use different cookies + should not allow cookies used in one method to carry over into other methods + when a cookie is set at the class level + should pass the proper cookies when requested multiple times + should include that cookie in the request + should allow the class defaults to be overridden + .follow_redirects + sets the follow_redirects option to false + sets follow redirects to true by default + +HTTParty::Logger::LogstashFormatter + #format + formats a response to be compatible with Logstash HTTParty::Logger .build - builds :logstash style logger - raises error when formatter exists - defaults level to :info defaults format to :apache - builds :custom style logger builds :curl style logger + builds :custom style logger + defaults level to :info + builds :logstash style logger + raises error when formatter exists + +HTTParty::HeadersProcessor + 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 not set at all + returns empty hash + when headers are dynamic + returns processed global and request specific headers Pending: (Failures listed here are expected and do not affect your suite's status) @@ -2113,54 +2149,54 @@ # Temporarily skipped with xit # ./spec/httparty/request_spec.rb:691 -Top 10 slowest examples (1.04 seconds, 43.8% of total time): +Top 10 slowest examples (1.37 seconds, 51.4% of total time): HTTParty::Request SSL certificate verification should provide the certificate used by the server via peer_cert - 0.16353 seconds ./spec/httparty/ssl_spec.rb:74 - HTTParty::Request SSL certificate verification should work when using ssl_ca_file with a certificate authority - 0.14697 seconds ./spec/httparty/ssl_spec.rb:37 + 0.1965 seconds ./spec/httparty/ssl_spec.rb:74 HTTParty::Request SSL certificate verification should work when using ssl_ca_file with a self-signed CA - 0.14599 seconds ./spec/httparty/ssl_spec.rb:33 + 0.19387 seconds ./spec/httparty/ssl_spec.rb:33 + HTTParty::Request SSL certificate verification should work when using ssl_ca_file with a certificate authority + 0.17556 seconds ./spec/httparty/ssl_spec.rb:37 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.13362 seconds ./spec/httparty/ssl_spec.rb:29 + 0.16924 seconds ./spec/httparty/ssl_spec.rb:29 HTTParty::Request SSL certificate verification should work when no trusted CA list is specified, when the verify option is set to false - 0.13099 seconds ./spec/httparty/ssl_spec.rb:19 - HTTParty::Request SSL certificate verification should fail when using ssl_ca_file and the server uses an unrecognized certificate authority - 0.06846 seconds ./spec/httparty/ssl_spec.rb:50 + 0.16517 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.06772 seconds ./spec/httparty/ssl_spec.rb:56 - HTTParty::Request SSL certificate verification should fail when no trusted CA list is specified, by default - 0.06435 seconds ./spec/httparty/ssl_spec.rb:13 + 0.09796 seconds ./spec/httparty/ssl_spec.rb:56 HTTParty::Request SSL certificate verification should fail when using ssl_ca_path and the server uses a bogus hostname - 0.06157 seconds ./spec/httparty/ssl_spec.rb:68 - HTTParty::Request::Body#call when params is hash when params has file is expected not to change `file.pos` - 0.05258 seconds ./spec/httparty/request/body_spec.rb:67 + 0.0975 seconds ./spec/httparty/ssl_spec.rb:68 + HTTParty::Request SSL certificate verification should fail when no trusted CA list is specified, with a bogus hostname, by default + 0.09684 seconds ./spec/httparty/ssl_spec.rb:23 + HTTParty::Request SSL certificate verification should fail when no trusted CA list is specified, by default + 0.09158 seconds ./spec/httparty/ssl_spec.rb:13 + HTTParty::Request SSL certificate verification should fail when using ssl_ca_file and the server uses a bogus hostname + 0.09007 seconds ./spec/httparty/ssl_spec.rb:62 Top 10 slowest example groups: HTTParty::Request - 0.09019 seconds average (1.08 seconds / 12 examples) ./spec/httparty/ssl_spec.rb:3 + 0.12441 seconds average (1.49 seconds / 12 examples) ./spec/httparty/ssl_spec.rb:3 HTTParty::Request::Body - 0.00562 seconds average (0.06182 seconds / 11 examples) ./spec/httparty/request/body_spec.rb:6 + 0.00433 seconds average (0.04766 seconds / 11 examples) ./spec/httparty/request/body_spec.rb:6 HTTParty::ConnectionAdapter - 0.00451 seconds average (0.31538 seconds / 70 examples) ./spec/httparty/connection_adapter_spec.rb:3 + 0.00301 seconds average (0.21094 seconds / 70 examples) ./spec/httparty/connection_adapter_spec.rb:3 HTTParty::Logger::CurlFormatter - 0.00311 seconds average (0.04038 seconds / 13 examples) ./spec/httparty/logger/curl_formatter_spec.rb:3 - HTTParty::Parser - 0.00219 seconds average (0.06349 seconds / 29 examples) ./spec/httparty/parser_spec.rb:3 - HTTParty - 0.00169 seconds average (0.19715 seconds / 117 examples) ./spec/httparty_spec.rb:3 + 0.00211 seconds average (0.02747 seconds / 13 examples) ./spec/httparty/logger/curl_formatter_spec.rb:3 HTTParty::Request - 0.00161 seconds average (0.45097 seconds / 280 examples) ./spec/httparty/request_spec.rb:3 + 0.00185 seconds average (0.51826 seconds / 280 examples) ./spec/httparty/request_spec.rb:3 + HTTParty + 0.00172 seconds average (0.20066 seconds / 117 examples) ./spec/httparty_spec.rb:3 HTTParty::Logger::LogstashFormatter - 0.00127 seconds average (0.00127 seconds / 1 example) ./spec/httparty/logger/logstash_formatter_spec.rb:3 + 0.00106 seconds average (0.00106 seconds / 1 example) ./spec/httparty/logger/logstash_formatter_spec.rb:3 + HTTParty::Decompressor + 0.00105 seconds average (0.01882 seconds / 18 examples) ./spec/httparty/decompressor_spec.rb:3 HTTParty::Logger::ApacheFormatter - 0.00118 seconds average (0.00236 seconds / 2 examples) ./spec/httparty/logger/apache_formatter_spec.rb:3 - HTTParty::CookieHash - 0.00092 seconds average (0.01099 seconds / 12 examples) ./spec/httparty/cookie_hash_spec.rb:3 + 0.00099 seconds average (0.00198 seconds / 2 examples) ./spec/httparty/logger/apache_formatter_spec.rb:3 + HTTParty::Response + 0.00092 seconds average (0.08436 seconds / 92 examples) ./spec/httparty/response_spec.rb:3 -Finished in 2.36 seconds (files took 0.5379 seconds to load) +Finished in 2.67 seconds (files took 0.59306 seconds to load) 715 examples, 0 failures, 1 pending -Randomized with seed 49605 +Randomized with seed 59172 ┌──────────────────────────────────────────────────────────────────────────────┐ @@ -2200,12 +2236,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/3612149/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/3612149/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/719170 and its subdirectories -I: Current time: Sun Jun 8 18:11:38 -12 2025 -I: pbuilder-time-stamp: 1749449498 +I: removing directory /srv/workspace/pbuilder/3612149 and its subdirectories +I: Current time: Mon Jun 9 20:12:29 +14 2025 +I: pbuilder-time-stamp: 1749449549