Diff of the two buildlogs: -- --- b1/build.log 2025-03-12 03:48:09.409769749 +0000 +++ b2/build.log 2025-03-12 03:48:59.443516204 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Tue Mar 11 15:46:37 -12 2025 -I: pbuilder-time-stamp: 1741751197 +I: Current time: Wed Apr 15 00:11:09 +14 2026 +I: pbuilder-time-stamp: 1776161469 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/trixie-reproducible-base.tgz] I: copying local configuration @@ -27,52 +27,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/3120442/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/2347295/tmp/hooks/D01_modify_environment starting +debug: Running on ionos15-amd64. +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 Apr 14 10: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/2347295/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/2347295/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='amd64' - DEBIAN_FRONTEND='noninteractive' - DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=20 ' - DISTRIBUTION='trixie' - HOME='/root' - HOST_ARCH='amd64' + 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]="37" [3]="1" [4]="release" [5]="x86_64-pc-linux-gnu") + BASH_VERSION='5.2.37(1)-release' + BUILDDIR=/build/reproducible-path + BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' + BUILDUSERNAME=pbuilder2 + BUILD_ARCH=amd64 + DEBIAN_FRONTEND=noninteractive + DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=42 ' + DIRSTACK=() + DISTRIBUTION=trixie + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=x86_64 + HOST_ARCH=amd64 IFS=' ' - INVOCATION_ID='ac2638d833e64f5690779ae686931cc0' - 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='3120442' - PS1='# ' - PS2='> ' + INVOCATION_ID=921aa7c3be0c449782088c3a8df0f0ea + LANG=C + LANGUAGE=et_EE:et + LC_ALL=C + MACHTYPE=x86_64-pc-linux-gnu + MAIL=/var/mail/root + OPTERR=1 + OPTIND=1 + OSTYPE=linux-gnu + PATH=/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path + PBCURRENTCOMMANDLINEOPERATION=build + PBUILDER_OPERATION=build + PBUILDER_PKGDATADIR=/usr/share/pbuilder + PBUILDER_PKGLIBDIR=/usr/lib/pbuilder + PBUILDER_SYSCONFDIR=/etc + PIPESTATUS=([0]="0") + POSIXLY_CORRECT=y + PPID=2347295 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.rK6DHiH4/pbuilderrc_qvOu --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.rK6DHiH4/b1 --logfile b1/build.log ruby-httparty_0.21.0-1.dsc' - SUDO_GID='111' - SUDO_UID='106' - SUDO_USER='jenkins' - TERM='unknown' - TZ='/usr/share/zoneinfo/Etc/GMT+12' - USER='root' - _='/usr/bin/systemd-run' - http_proxy='http://46.16.76.132: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.rK6DHiH4/pbuilderrc_N7vc --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.rK6DHiH4/b2 --logfile b2/build.log ruby-httparty_0.21.0-1.dsc' + SUDO_GID=111 + SUDO_UID=106 + SUDO_USER=jenkins + TERM=unknown + TZ=/usr/share/zoneinfo/Etc/GMT-14 + UID=0 + USER=root + _='I: set' + http_proxy=http://213.165.73.152:3128 I: uname -a - Linux ionos11-amd64 6.1.0-31-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.128-1 (2025-02-07) x86_64 GNU/Linux + Linux i-capture-the-hostname 6.12.12+bpo-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.12.12-1~bpo12+1 (2025-02-23) x86_64 GNU/Linux I: ls -l /bin - lrwxrwxrwx 1 root root 7 Mar 4 11:20 /bin -> usr/bin -I: user script /srv/workspace/pbuilder/3120442/tmp/hooks/D02_print_environment finished + lrwxrwxrwx 1 root root 7 Mar 4 2025 /bin -> usr/bin +I: user script /srv/workspace/pbuilder/2347295/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy @@ -271,7 +303,7 @@ Get: 145 http://deb.debian.org/debian trixie/main amd64 ruby-rspec-mocks all 3.13.0c0e0m0s1-2 [81.3 kB] Get: 146 http://deb.debian.org/debian trixie/main amd64 ruby-rspec all 3.13.0c0e0m0s1-2 [5184 B] Get: 147 http://deb.debian.org/debian trixie/main amd64 ruby-webmock all 3.24.0-2 [68.5 kB] -Fetched 49.4 MB in 1s (43.6 MB/s) +Fetched 49.4 MB in 3s (16.1 MB/s) Preconfiguring packages ... 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 ... 19800 files and directories currently installed.) @@ -758,8 +790,8 @@ Setting up tzdata (2025a-2) ... Current default time zone: 'Etc/UTC' -Local time is now: Wed Mar 12 03:47:30 UTC 2025. -Universal Time is now: Wed Mar 12 03:47:30 UTC 2025. +Local time is now: Tue Apr 14 10:11:37 UTC 2026. +Universal Time is now: Tue Apr 14 10:11:37 UTC 2026. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up ruby-minitest (5.25.4-2) ... @@ -894,7 +926,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/2347295/tmp/hooks/A99_set_merged_usr starting +Not re-configuring usrmerge for trixie +I: user script /srv/workspace/pbuilder/2347295/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 @@ -931,7 +967,7 @@ │ ruby-httparty: Installing files and building extensions for ruby3.3 │ └──────────────────────────────────────────────────────────────────────────────┘ -/usr/bin/ruby3.3 -S gem build --config-file /dev/null --verbose /tmp/d20250311-3133221-szryqb/gemspec +/usr/bin/ruby3.3 -S gem build --config-file /dev/null --verbose /tmp/d20260415-2372322-9r7h03/gemspec WARNING: description and summary are identical WARNING: open-ended dependency on multi_xml (>= 0.5.2) is not recommended if multi_xml is semantically versioned, use: @@ -944,7 +980,7 @@ Name: httparty Version: 0.21.0 File: httparty-0.21.0.gem -/usr/bin/ruby3.3 -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/d20250311-3133221-szryqb/httparty-0.21.0.gem +/usr/bin/ruby3.3 -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/d20260415-2372322-9r7h03/httparty-0.21.0.gem /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 /build/reproducible-path/ruby-httparty-0.21.0/debian/ruby-httparty/usr/share/rubygems-integration/all/gems/httparty-0.21.0/lib/httparty/connection_adapter.rb @@ -1011,362 +1047,85 @@ All examples were filtered out; ignoring {:focus=>true} -Randomized with seed 26120 +Randomized with seed 26553 -HTTParty::Logger - .build - builds :custom style logger - defaults level to :info - raises error when formatter exists - builds :logstash style logger - defaults format to :apache - builds :curl style logger - -HTTParty::Parser - .supports_format? - returns true for a supported format - returns false for an unsupported format - parsers - parses html by simply returning the body - parses json with JSON - parses csv with CSV - parses xml with MultiXml - parses plain text by simply returning the body - .supported_formats - returns a unique set of supported formats represented by symbols - .formats - returns the SupportedFormats constant - returns the SupportedFormats constant for subclasses - .call - calls #parse on the parser - generates an HTTParty::Parser instance with the given body and format - .SupportedFormats - returns a hash - .format_from_mimetype - returns nil when the mimetype is not supported - returns a symbol representing the format mimetype - #parse - returns nil for a body with spaces only - returns the unparsed body when the format is unsupported - does not raise exceptions for bodies with invalid encodings - returns nil for an empty body - returns nil for a nil body - ignores utf-8 bom - returns nil for a 'null' body - parses frozen strings - parses ascii 8bit encoding - attempts to parse supported formats - #supports_format? - utilizes the class method to determine if the format is supported - #parse_supported_format - calls the parser for the given format - when a parsing method does not exist for the given format - raises an exception - raises a useful exception message for subclasses - -HTTParty::CookieHash - #to_cookie_string - should format the key/value pairs, delimited by semi-colons - should not include SameSite attribute - should not include client side only cookies even when attributes use camal case - should not mutate the hash - should not include client side only cookies - #add_cookies - with a hash - should overwrite any existing key - should add new key/value pairs to the hash - with a string - should add new key/value pairs to the hash - should handle an empty cookie parameter - should handle '=' within cookie value - should overwrite any existing key - with other class - should error - -HTTParty - connection_adapter - should set the connection_adapter - should process a request with a connection from the adapter - should not set the connection_adapter_options when not provided - should set the connection_adapter_options when provided - with multiple class definitions - should not run over each others options - .normalize_base_uri - should add https if not present for ssl requests - should not modify the parameter - should not remove https for ssl requests - should not treat uri's with a port of 4430 as ssl - should add http if not present for non ssl requests - #resend_on_redirect - sets resend_on_redirect option to false - sets resend_on_redirect to true by default - ssl_version - should set the ssl_version content - headers - should be able to be updated - uses the class headers when sending a request - should default to empty hash - should be able to accept block as header value - should pass options as argument to header block value - does not modify default_options when no arguments are passed - merges class headers with request headers - overrides class headers with request headers - with cookies - adds cookies to the headers - utilizes the class-level cookies - doesnt modify default headers - adds optional cookies to the optional headers - when posting file - changes content-type headers to multipart/form-data - when headers passed as symbols - converts default headers to string - converts them to string - base uri - should have writer - should have reader - should not modify the parameter during assignment - two child classes inheriting from one parent - should dup the proc on the child class - doesn't modify the parent's default cookies - works with lambda values - inherits default_cookies from the parent class - does not modify each others inherited attributes - doesn't modify hashes in the parent's default options - inherits default_options from the superclass - doesn't modify the parent's default options - debug_output - stores the given stream as a default_option - stores the $stderr stream by default - cookies - should allow a cookie to be specified with a one-off request - should raise an ArgumentError if passed a non-Hash - should not be in the headers by default - in a class with multiple methods that use different cookies - should not allow cookies used in one method to carry over into other methods - when a cookie is set at the class level - should allow the class defaults to be overridden - should pass the proper cookies when requested multiple times - should include that cookie in the request - pkcs12 - should set the p12 content - should set the password - ciphers - should set the ciphers content - format - should not allow funky format - should only print each format once with an exception - should allow json - should allow xml - sets the default parser - should allow csv - does not reset parser to the default parser - should allow plain - digest http authentication - should work - .raise_on - when parameters is a fixnum - sets raise_on option - when parameters is an array - sets raise_on option - grand parent with inherited callback - continues running the #inherited on the parent - parser - raises UnsupportedFormat when the parser cannot handle the format - should set parser options - should be able parse response with custom parser - does not validate format whe custom parser is a proc - #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 - .disable_rails_query_string_format - sets the query string normalizer to HTTParty::Request::NON_RAILS_QUERY_STRING_NORMALIZER - head requests should follow redirects requesting HEAD only - should remain HEAD request across redirects, unless specified otherwise - default timeout - should support floats - should support updating - should raise an exception if unsupported type provided - should default to nil - .query_string_normalizer - sets the query_string_normalizer option - uri_adapter - with Addressable::URI - handles international domains - with custom URI Adaptor - should raise an ArgumentError if uri_adapter doesn't implement parse method - should set the uri_adapter - should process a request with a uri instance parsed from the uri_adapter - basic http authentication - should work - default params - should be able to be updated - should default to empty hash - with explicit override of automatic redirect handling - should fail with redirected PATCH - should fail with redirected POST - should fail with redirected COPY - should fail with redirected HEAD - should fail with redirected DELETE - should fail with redirected MKCOL - should fail with redirected PUT - should fail with redirected MOVE - should fail with redirected OPTIONS - should fail with redirected GET - #get - should be able parse response type csv automatically - should return an empty body if stream_body option is turned on - should be able to get html - should be able to get chunked html - should accept http URIs -[DEPRECATION] HTTParty will no longer override `response#nil?`. This functionality will be removed in future versions. Please, add explicit check `response.body.nil? || response.body.empty?`. For more info refer to: https://github.com/jnunemaker/httparty/issues/568 -/usr/share/rubygems-integration/all/gems/rspec-expectations-3.13.0/lib/rspec/matchers/built_in/be.rb:69:in `match' - should parse empty response fine - should not get undefined method add_node for nil class for the following xml - should be able parse response type json automatically - should be able parse response type xml automatically - should accept webcal URIs - should accept https URIs - should raise an InvalidURIError on URIs that can't be parsed at all - when streaming body - is expected to eq # - #maintain_method_across_redirects - sets maintain_method_across_redirects to true by default - sets the maintain_method_across_redirects option to false - #no_follow - sets no_follow to false by default - sets the no_follow option to true - .follow_redirects - sets follow redirects to true by default - sets the follow_redirects option to false - pem - should set the pem content - should set the password to nil if it's not provided - should set the password - http_proxy - should set the address - should set the proxy user and pass when they are provided - -HTTParty::Request - SSL certificate verification - should provide the certificate used by the server via peer_cert - should work when no trusted CA list is specified, even with a bogus hostname, when the verify option is set to true - should work when using ssl_ca_file with a self-signed CA - should work when using ssl_ca_path with a certificate authority - should work when using ssl_ca_file with a certificate authority -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/3.3.0/openssl/ssl.rb:527:in `accept': SSL_accept returned=1 errno=107 peeraddr=(null) state=error: tlsv1 alert unknown ca (SSL alert number 48) (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/3.3.0/openssl/ssl.rb:527:in `accept' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' - should fail when using ssl_ca_path and the server uses an unrecognized certificate authority -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/3.3.0/openssl/ssl.rb:527:in `accept': SSL_accept returned=1 errno=107 peeraddr=(null) state=error: ssl/tls alert bad certificate (SSL alert number 42) (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/3.3.0/openssl/ssl.rb:527: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.3.0/openssl/ssl.rb:527:in `accept': SSL_accept returned=1 errno=107 peeraddr=(null) state=error: tlsv1 alert unknown ca (SSL alert number 48) (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/3.3.0/openssl/ssl.rb:527: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.3.0/openssl/ssl.rb:527:in `accept': SSL_accept returned=1 errno=107 peeraddr=(null) state=error: tlsv1 alert unknown ca (SSL alert number 48) (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/3.3.0/openssl/ssl.rb:527:in `accept' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' - should fail when no trusted CA list is specified, by default -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/3.3.0/openssl/ssl.rb:527:in `accept': SSL_accept returned=1 errno=107 peeraddr=(null) state=error: tlsv1 alert unknown ca (SSL alert number 48) (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/3.3.0/openssl/ssl.rb:527:in `accept' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' - should fail when using ssl_ca_path and the server uses a bogus hostname -# terminated with exception (report_on_exception is true): -/usr/lib/ruby/3.3.0/openssl/ssl.rb:527:in `accept': SSL_accept returned=1 errno=107 peeraddr=(null) state=error: tlsv1 alert unknown ca (SSL alert number 48) (OpenSSL::SSL::SSLError) - from /usr/lib/ruby/3.3.0/openssl/ssl.rb:527:in `accept' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' - from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' - should fail when no trusted CA list is specified, with a bogus hostname, by default - should work when no trusted CA list is specified, when the verify option is set to false +Net::HTTPHeader::DigestAuthenticator + with multiple authenticate headers + should set prefix + should set username + should set cnonce + should set digest-uri + should set qop + should set nonce-count + should set response + when quality of protection (qop) is unquoted + should still set qop + with an opaque value in the response header + should set opaque + with specified quality of protection (qop) + should set digest-uri + should set prefix + should set response + should set qop + should set username + should set nonce-count + should set cnonce + with a cookie value in the response header + should set cookie header + with algorithm specified + should recognise algorithm was specified + should set the algorithm header + with md5-sess algorithm specified + should set response using md5-sess algorithm + should set the algorithm header + should recognise algorithm was specified + without a cookie value in the response header + should set empty cookie header array + 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 + Net::HTTPHeader#digest_auth + should set the authorization header + with unspecified quality of protection (qop) + should not set nonce-count + should set username + should set response + should not set cnonce + should not set qop + should set prefix + should set digest-uri HTTParty::HeadersProcessor + when global and request specific headers are set + returns merged global and request specific headers when headers are not set at all returns empty hash + when only global headers are set + returns stringified global headers when only request specific headers are set returns stringified request specific headers - when global and request specific headers are set - returns merged global and request specific headers when headers are dynamic returns processed global and request specific headers - when only global headers are set - returns stringified global headers - -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 string - is expected to eq "name=Bob%20Jones" - when params is hash - is expected to eq "people%5B%5D=Bob%20Jones&people%5B%5D=Mike%20Smith" - when params has file - is expected not to change `file.pos` - is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[avatar]\";...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" - when passing multipart as an option - is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[first_name...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" - when file name contains [ " \r \n ] - is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[attachment...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" - file object responds to original_filename - is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[avatar]\";...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" -HTTParty::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 body - logs headers - when request is logged - and query is present - logs Query - logs query params - and headers are present - logs Headers - logs headers keys - and headers are not present - not log Headers - when request raw_body is present - not logs request body - and query is not present - not logs Query - and request's option 'base_uri' is present - logs url - and request's option 'base_uri' is not present - logs url - -HTTParty::ResponseFragment - access to fragment - has access to delegators - -HTTParty::Logger::ApacheFormatter - #format - formats a response in a style that resembles apache's access log - when there is a parsed response - can handle the Content-Length header - -HTTParty::Logger::LogstashFormatter - #format - formats a response to be compatible with Logstash +HTTParty::Error + HTTParty::ResponseError + #ancestors + is expected to include HTTParty::Error + HTTParty::DuplicateLocationHeader + #ancestors + is expected to include HTTParty::ResponseError + HTTParty::UnsupportedURIScheme + #ancestors + is expected to include HTTParty::Error + HTTParty::RedirectionTooDeep + #ancestors + is expected to include HTTParty::ResponseError + HTTParty::UnsupportedFormat + #ancestors + is expected to include HTTParty::Error + #ancestors + is expected to include StandardError HTTParty::HashConversions .normalize_param @@ -1383,539 +1142,394 @@ nested params creates a params string from a hash -HTTParty::Decompressor - .SupportedEncodings - returns a hash - #decompress - when encoding is unsupported - 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 nil - behaves like returns the body - is expected to eq "body" - 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 encoding is "zstd" - when zstd raises error - is expected to eq nil - when zstd-ruby included - is expected to eq "foobar" - when zstd-ruby gem not included - behaves like returns nil - is expected to be nil - when encoding is "compress" - when ruby-lzws included - is expected to eq "foobar" - when ruby-lzws raises error - is expected to eq nil - when compress-lzw included - is expected to eq "foobar" - when LZW gem not included - behaves like returns nil - is expected to be nil - when body is nil - behaves like returns nil - is expected to be nil - when encoding is blank - behaves like returns the body - is expected to eq "body" - when encoding is "identity" - behaves like returns the body - is expected to eq "body" - -Net::HTTPHeader::DigestAuthenticator - when quality of protection (qop) is unquoted - should still set qop - Net::HTTPHeader#digest_auth - should set the authorization header - without a cookie value in the response header - should set empty cookie header array - 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 a cookie value in the response header - should set cookie header - with unspecified quality of protection (qop) - should set digest-uri - should set prefix - should set response - should not set cnonce - should not set qop - should set username - should not set nonce-count - with algorithm specified - should recognise algorithm was specified - should set the algorithm header - with md5-sess algorithm specified - should recognise algorithm was specified - should set response using md5-sess algorithm - should set the algorithm header - with specified quality of protection (qop) - should set username - should set response - should set nonce-count - should set digest-uri - should set qop - should set prefix - should set cnonce - with an opaque value in the response header - should set opaque - with multiple authenticate headers - should set username - should set response - should set qop - should set prefix - should set cnonce - should set nonce-count - should set digest-uri +HTTParty::Logger::LogstashFormatter + #format + formats a response to be compatible with Logstash -HTTParty::ConnectionAdapter - .call - calls #connection on the connection adapter - generates an HTTParty::ConnectionAdapter instance with the given uri and options - #connection - the resulting connection - is expected to be an instance of Net::HTTP - when debug_output - is not provided - does not set_debug_output - is set to $stderr - has debug output set - when providing PEM certificates - when scheme is https - will verify the certificate - uses the provided PEM certificate - when options include verify=false - should not verify the certificate - when options include verify_peer=false - should not verify the certificate - when scheme is not https - has no PEM certificate - when setting timeout - and timeout is a string - doesn't set the 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 - when max_retries is not set - doesn't set the max_retries - 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 providing nil as proxy address - is expected not to be a proxy - does pass nil proxy parameters to the connection, this forces to not use a proxy - when timeout is not set and write_timeout is set to 8 seconds - should not set the open timeout - should not set the read timeout - #write_timeout - is expected to eq 8 - when not providing a proxy address - does not pass any proxy parameters to the connection - when providing proxy address and port - is expected to be a proxy - #proxy_address - is expected to eq "1.2.3.4" - as well as proxy user and password - #proxy_pass - is expected to eq "pass" - #proxy_user - is expected to eq "user" - #proxy_port - is expected to eq 8080 - when timeout is set and read_timeout is set to 6 seconds - should override the timeout option - #open_timeout - is expected to eq 5 - #write_timeout - is expected to eq 5 - #read_timeout - is expected to eq 6 - when timeout is set and write_timeout is set to 8 seconds - should override the timeout option - #write_timeout - is expected to eq 8 - when timeout is not set and read_timeout is set to 6 seconds - should not set the write_timeout - should not set the open_timeout - #read_timeout - is expected to eq 6 - 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 providing PKCS12 certificates - when scheme is not https - has no PKCS12 certificate - when scheme is https - will verify the certificate - uses the provided P12 certificate - when options include verify_peer=false - should not verify the certificate - when options include verify=false - should not verify the certificate - using port 80 - is expected not to use ssl - when timeout is not set - doesn't set the timeout - when timeout is set and open_timeout is set to 7 seconds - should override the timeout option - #read_timeout - is expected to eq 5 - #open_timeout - is expected to eq 7 - #write_timeout - is expected to eq 5 - when providing a local bind address and port - #local_port - is expected to eq 12345 - #local_host - is expected to eq "127.0.0.1" - when setting max_retries - and max_retries is a string - doesn't set the max_retries - to 5 times - #max_retries - is expected to eq 5 - to 0 times - #max_retries - is expected to eq 0 - when dealing with ssl - https scheme with default port - is expected to use ssl - should use the specified cert store, when one is given - is expected to use cert store # - when ssl version is set - sets ssl version - uses the system cert_store, by default - 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 - specifying ciphers - should set the ciphers on the connection - when dealing with IPv6 - strips brackets from the address - initialization - raises an ArgumentError if the uri is a String - sets the options - takes a URI as input - also accepts an optional options hash - sets the uri - raises an ArgumentError if the uri is nil +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 + should not fail for missing mime type [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' [DEPRECATION] HTTParty will no longer override `response#nil?`. This functionality will be removed in future versions. Please, add explicit check `response.body.nil? || response.body.empty?`. For more info refer to: https://github.com/jnunemaker/httparty/issues/568 /usr/share/rubygems-integration/all/gems/rspec-expectations-3.13.0/lib/rspec/matchers/built_in/be.rb:69:in `match' should not attempt to parse empty responses - should not fail for missing mime type - parsing responses - should process response with a nil body - should process utf-16 charset with big endian bom correctly - should handle json automatically - should handle xml automatically - should include any HTTP headers in the returned response - should handle csv automatically - should assume utf-16 little endian if options has been chosen - should perform no encoding if the charset is not available - should handle utf-8 bom in xml - should perform no encoding if the content type is specified but no charset is specified - should handle utf-8 bom in json - when body has ascii-8bit encoding - 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 not decompress the body if the :skip_decompression option is set - should remove the Content-Encoding header if uncompressed - should decompress the body and remove the Content-Encoding header - with non-200 responses - parses response lazily so codes can be checked prior - should return a valid object for 5xx response - should return a valid object for 4xx response - 3xx responses -[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 - returns the HTTParty::Response when the 300 does not contain a location header - raises an error if redirect has duplicate location header - calls block given to perform with each redirect (PENDING: Temporarily skipped with xit) - redirects including port - handles multiple redirects and relative location headers on different hosts - redirects if a 300 contains a location header - when assume_utf16_is_big_endian is true - processes stubbed frozen body correctly - should process utf-16 charset with little endian bom correctly + ::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 a request that 308 redirects + infinitely + should raise an exception once + should update cookies with redirects + should be handled by HEAD transparently + should be handled by POST transparently + should be handled by PATCH transparently should keep track of cookies between redirects - should be handled by LOCK transparently + should be handled by DELETE transparently + should be handled by PUT transparently + should keep cookies between redirects + should be handled by MKCOL transparently + should be handled by COPY transparently + should be handled by UNLOCK transparently + should handle multiple Set-Cookie headers between redirects + should be handled by MOVE transparently should maintain method in resulting request - should be handled by POST transparently + should maintain method in resulting request if options[:maintain_method_across_redirects] is true + should be handled by LOCK transparently + should be handled by GET transparently should log the redirection + should maintain method in resulting request if options[:maintain_method_across_redirects] is false should be handled by OPTIONS transparently + a request that 303 redirects + once + should be handled by POST transparently should be handled by PUT transparently - should keep cookies between redirects + should be handled by HEAD transparently + should be handled by GET transparently + should handle multiple Set-Cookie headers between redirects + should be handled by MOVE transparently + should update cookies with redirects + should be handled by PATCH transparently + should not make resulting request a get request if options[:maintain_method_across_redirects] and options[:resend_on_redirect] is true + should make resulting request a get request if it not already + should be handled by DELETE transparently + should be handled by COPY 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 LOCK transparently should be handled by UNLOCK transparently + should log the redirection + should make resulting request a get request if options[:maintain_method_across_redirects] is false + should keep cookies between redirects + should be handled by MKCOL transparently + should be handled by OPTIONS transparently + should keep track of cookies between redirects + infinitely + should raise an exception + #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 300 redirects + once should handle multiple Set-Cookie headers between redirects + should not make resulting request a get request if options[:maintain_method_across_redirects] is true + should be handled by POST transparently + should be handled by PUT transparently + should be handled by PATCH transparently should be handled by DELETE transparently - should maintain method in resulting request if options[:maintain_method_across_redirects] is false - should update cookies with redirects + should keep cookies between redirects should be handled by MKCOL transparently + should be handled by OPTIONS transparently + should make resulting request a get request if it not already + should be handled by UNLOCK transparently + should keep track of cookies between redirects + should be handled by GET transparently + should update cookies with redirects + should log the redirection + should be handled by COPY transparently + should be handled by HEAD transparently + should be handled by LOCK transparently + should be handled by MOVE transparently + infinitely + should raise an exception + options + should normalize base uri when specified as request option + should use body_stream when configured + should use basic auth when configured + digest_auth + should be used when configured and the response is 401 + should not be used when configured and the response is 200 + should not send credentials more than once + should merge cookies from request and a 401 response + should maintain cookies returned from a 401 response + a request that 305 redirects + once + should be handled by DELETE transparently should be handled by COPY transparently + should keep track of cookies between redirects + should not make resulting request a get request if options[:maintain_method_across_redirects] is true should be handled by MOVE transparently + should be handled by PUT transparently + should be handled by LOCK transparently + should be handled by POST transparently + should be handled by OPTIONS transparently + should be handled by UNLOCK transparently should be handled by GET transparently - should be handled by PATCH transparently should be handled by HEAD transparently - should maintain method in resulting request if options[:maintain_method_across_redirects] is true + should be handled by PATCH transparently + should log the redirection + should make resulting request a get request if it not already + should keep cookies between redirects + should handle multiple Set-Cookie headers between redirects + should be handled by MKCOL transparently + should update cookies with redirects infinitely should raise an exception - ::NON_RAILS_QUERY_STRING_NORMALIZER - doesn't modify strings - when the query is a hash - correctly handles nil values - when the query is an array - doesn't include brackets - URI encodes array values http should get a connection from the connection_adapter - ::JSON_API_QUERY_STRING_NORMALIZER - doesn't modify strings - when the query is an array - URI encodes array values - doesn't include brackets - when the query is a hash - correctly handles nil values initialization + sets parser to the optional parser + sets connection_adapter to HTTParty::ConnectionAdapter sets connection_adapter to the optional connection_adapter sets parser to HTTParty::Parser - sets connection_adapter to HTTParty::ConnectionAdapter - sets parser to the optional parser 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 wasn't set explicitly - sets basic auth from uri when basic auth options was set explicitly uses basic auth from url anyway - #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 + when basic auth options wasn't set explicitly + sets basic auth from uri a request that 307 redirects once - should be handled by POST transparently - should log the redirection - should be handled by OPTIONS transparently - should keep track of cookies between redirects - should be handled by COPY transparently should be handled by MKCOL transparently - should keep cookies between redirects - should maintain method in resulting request - should be handled by MOVE transparently - should maintain method in resulting request if options[:maintain_method_across_redirects] is true - should update cookies with redirects - should be handled by DELETE transparently - should be handled by GET transparently should be handled by PUT transparently - should be handled by PATCH transparently - should be handled by UNLOCK transparently should handle multiple Set-Cookie headers between redirects + should keep track of cookies between redirects + should maintain method in resulting request if options[:maintain_method_across_redirects] is true + should update cookies with redirects should be handled by HEAD transparently - should be handled by LOCK transparently + should log the redirection + should keep cookies between redirects + should maintain method in resulting request + should be handled by OPTIONS transparently + should be handled by POST transparently + should be handled by PATCH transparently + should be handled by GET transparently should maintain method in resulting request if options[:maintain_method_across_redirects] is false + should be handled by COPY transparently + should be handled by LOCK transparently + should be handled by UNLOCK transparently + should be handled by MOVE transparently + should be handled by DELETE transparently infinitely should raise an exception + #format_from_mimetype + should handle application/vnd.api+json + should handle text/json + should handle application/hal+json + returns nil when using a default parser + returns nil for an unrecognized mimetype + should handle text/xml + should handle application/xml + should handle application/javascript + should handle text/comma-separated-values + should handle text/javascript + should handle application/csv + should handle text/csv + should handle application/json #uri - 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 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 + does not add an empty query string when default_params are blank does not duplicate query string parameters when uri is called twice respects the query string normalization proc when representing an array returns a Rails style query string - marshalling - properly marshals the request object + redirects + returns correct path when the server sets the location header to a filename + returns correct path when the server sets the location header to a full uri + returns correct path when the server sets the location header to a network-path reference + location header is an absolute path + returns the correct path when location has no leading slash + returns correct path when location has leading slash + argument validation + should raise argument error if basic_auth and digest_auth are both present + should raise argument error if basic_auth is not a hash + should raise argument error if digest_auth is not a hash + should raise argument error if headers is not a hash + should raise argument error if http method is post and query is not hash + should raise argument error if options method is not http accepted method + should raise RedirectionTooDeep error if limit is negative Net::HTTP decompression - with skip_decompression false (default) + with skip_decompression true with no headers specified - behaves like enables Net::HTTP decompression - is expected to eq true + 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" - with accept-encoding (lowercase) specified + with Accept-Encoding specified behaves like sets custom Accept-Encoding is expected to eq "custom" - behaves like enables Net::HTTP decompression - is expected to eq true - with Accept-Encoding specified - behaves like enables Net::HTTP decompression - is expected to eq true + behaves like disables Net::HTTP decompression + is expected to eq false + with Accept-Encoding and other headers specified + behaves like disables Net::HTTP decompression + is expected to eq false behaves like sets custom Accept-Encoding is expected to eq "custom" with 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 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 skip_decompression true - with Accept-Encoding and other headers specified behaves like disables Net::HTTP decompression is expected to eq false + with accept-encoding (lowercase) specified behaves like sets custom Accept-Encoding is expected to eq "custom" - with other headers specified behaves like disables Net::HTTP decompression is expected to eq false + with skip_decompression false (default) + with other headers specified + behaves like enables Net::HTTP decompression + is expected to eq true behaves like sets default Accept-Encoding is expected to eq "gzip;q=1.0,deflate;q=0.6,identity;q=0.3" + with Accept-Encoding and other headers specified + behaves like sets custom Accept-Encoding + is expected to eq "custom" + behaves like enables Net::HTTP decompression + is expected to eq true with no headers specified + behaves like enables Net::HTTP decompression + is expected to eq true behaves like sets default Accept-Encoding is expected to eq "gzip;q=1.0,deflate;q=0.6,identity;q=0.3" - behaves like disables Net::HTTP decompression - is expected to eq false - with accept-encoding (lowercase) specified + 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" - behaves like disables Net::HTTP decompression - is expected to eq false - with Accept-Encoding specified - behaves like disables Net::HTTP decompression - is expected to eq false + with accept-encoding (lowercase) specified behaves like sets custom Accept-Encoding is expected to eq "custom" - a request that 305 redirects + behaves like enables Net::HTTP decompression + is expected to eq true + a request that returns 304 + should report 304 with a MOVE request + should report 304 with a PUT request + should report 304 with a OPTIONS request + should report 304 with a HEAD request + should report 304 with a DELETE request + should be handled by LOCK transparently + should report 304 with a MKCOL request + should report 304 with a PATCH request + should report 304 with a GET request + should not log the redirection + should report 304 with a POST request + should report 304 with a COPY request + should be handled by UNLOCK transparently + a request that 301 redirects once + should be handled by PATCH transparently + should handle multiple Set-Cookie headers between redirects + should be handled by HEAD transparently + should be handled by LOCK transparently + should be handled by OPTIONS transparently + should log the redirection should be handled by POST transparently - should not make resulting request a get request if options[:maintain_method_across_redirects] is true - should be handled by MOVE transparently - should update cookies with redirects should be handled by MKCOL transparently - should handle multiple Set-Cookie headers between redirects - should make resulting request a get request if it not already - should be handled by PATCH transparently + should update cookies with redirects + should be handled by MOVE transparently + should be handled by DELETE transparently + should be handled by UNLOCK transparently + should keep track of cookies between redirects + should not make resulting request a get request if options[:maintain_method_across_redirects] is true should be handled by COPY transparently should be handled by PUT transparently - should keep track of cookies between redirects - should be handled by UNLOCK transparently - should be handled by OPTIONS transparently - should keep cookies between redirects - should be handled by LOCK transparently - should be handled by DELETE transparently should be handled by GET transparently - should be handled by HEAD transparently - should log the redirection + should keep cookies between redirects + should make resulting request a get request if it not already infinitely should raise an exception - a request that 303 redirects + #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 a relative path + should send Authorization header when redirecting to the same host + parsing responses + should perform no encoding if the charset is not available + should handle utf-8 bom in json + should handle xml automatically + should process utf-16 charset with big endian bom correctly + should handle json automatically + should assume utf-16 little endian if options has been chosen + should perform no encoding if the content type is specified but no charset is specified + should process response with a nil body + should handle csv automatically + should include any HTTP headers in the returned response + should handle utf-8 bom in xml + decompression + should not decompress the body if the :skip_decompression option is set + should not decompress unrecognized Content-Encoding + should decompress the body and remove the Content-Encoding header + should remove the Content-Encoding header if uncompressed + when body has ascii-8bit encoding + processes charset in content type properly + processes quoted charset in content type properly + processes charset in content type properly if it has a different case + when stubed body is frozen + processes frozen body correctly + with non-200 responses + parses response lazily so codes can be checked prior + should return a valid object for 5xx response + should return a valid object for 4xx response + 3xx responses + returns the HTTParty::Response when the 300 does not contain a location header + redirects if a 300 contains a location header + redirects if a 300 contains a relative location header + calls block given to perform with each redirect (PENDING: Temporarily skipped with xit) + handles multiple redirects and relative location headers on different hosts +[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 + raises an error if redirect has duplicate location header + redirects including port + when assume_utf16_is_big_endian is true + processes stubbed frozen body correctly + should process utf-16 charset with little endian bom correctly + a request that 302 redirects once - should be handled by POST transparently - should be handled by DELETE transparently should log the redirection - 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 PUT transparently should be handled by HEAD transparently + should be handled by MOVE transparently should be handled by COPY transparently - should keep cookies between redirects - should make resulting request a get request if options[:maintain_method_across_redirects] is false - should be handled by GET transparently - should be handled by PUT transparently - should make resulting request a get request if options[:maintain_method_across_redirects] is true but options[:resend_on_redirect] is false - should update cookies with redirects + should be handled by LOCK transparently + should be handled by DELETE transparently should be handled by MKCOL transparently - should make resulting request a get request if it not already - should handle multiple Set-Cookie headers between redirects + should be handled by POST transparently + should update cookies with redirects should keep track of cookies between redirects - should be handled by PATCH transparently - should be handled by LOCK transparently should be handled by UNLOCK transparently - should be handled by MOVE transparently should be handled by OPTIONS transparently - infinitely - should raise an exception - with POST http method - should raise argument error if query is not a hash - a request that 302 redirects - once - should be handled by POST transparently - should update cookies with redirects - should handle multiple Set-Cookie headers between redirects - should be handled by COPY transparently - should be handled by MOVE transparently - should be handled by MKCOL transparently - should be handled by GET transparently should keep cookies between redirects - should keep track of cookies between redirects + should be handled by GET transparently should make resulting request a get request if it not already - should be handled by PUT transparently - should not make resulting request a get request if options[:maintain_method_across_redirects] is true - should be handled by LOCK transparently + should handle multiple Set-Cookie headers between redirects should be handled by PATCH transparently - should be handled by OPTIONS transparently - should be handled by UNLOCK transparently - should be handled by DELETE transparently - should log the redirection - should be handled by HEAD transparently + should not make resulting request a get request if options[:maintain_method_across_redirects] is true infinitely should raise an exception - a request that returns 304 - should report 304 with a OPTIONS request - should not log the redirection - should be handled by UNLOCK transparently - should report 304 with a DELETE request - should report 304 with a HEAD request - should report 304 with a MKCOL request - should report 304 with a POST request - should report 304 with a PATCH request - should report 304 with a COPY request - should report 304 with a MOVE request - should report 304 with a GET request - should report 304 with a PUT request - should be handled by LOCK transparently + with POST http method + should raise argument error if query is not a hash + ::JSON_API_QUERY_STRING_NORMALIZER + doesn't modify strings + when the query is an array + URI encodes array values + doesn't include brackets + when the query is a hash + correctly handles nil values + marshalling + properly marshals the request object #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= @@ -1923,220 +1537,642 @@ 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 - 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 basic_auth is not a hash - should raise argument error if options method is not http accepted method - should raise argument error if headers is not a hash - should raise RedirectionTooDeep error if limit is negative - #format_from_mimetype - should handle text/comma-separated-values - should handle text/json - should handle application/csv - should handle application/javascript - returns nil for an unrecognized mimetype - should handle application/vnd.api+json - should handle text/xml - should handle application/json - should handle application/hal+json - returns nil when using a default parser - should handle text/csv - should handle application/xml - should handle text/javascript - #send_authorization_header? - basic_auth - should send Authorization header when redirecting to a relative path - should send Authorization header when redirecting to the same host - should send Authorization header when redirecting to a different port on the same host - should not send Authorization header when redirecting to a different host - a request that 301 redirects - once - should be handled by PATCH transparently - should keep track of cookies between redirects - should be handled by OPTIONS transparently - should be handled by MOVE transparently - should be handled by DELETE transparently - should be handled by PUT transparently - should be handled by POST transparently - should be handled by UNLOCK transparently - should be handled by MKCOL transparently - should be handled by COPY transparently - should be handled by GET transparently - should handle multiple Set-Cookie headers between redirects - should make resulting request a get request if it not already - should log the redirection - should not make resulting request a get request if options[:maintain_method_across_redirects] is true - should keep cookies between redirects - should be handled by HEAD transparently - should update cookies with redirects - should be handled by LOCK transparently - infinitely - should raise an exception - a request that 300 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 be handled by MOVE transparently - should be handled by UNLOCK transparently - should be handled by PATCH transparently - should keep cookies between redirects - should be handled by DELETE transparently - should be handled by PUT transparently - should update cookies with redirects - should be handled by MKCOL transparently - should be handled by GET transparently - should not make resulting request a get request if options[:maintain_method_across_redirects] is true - should handle multiple Set-Cookie headers between redirects - should keep track of cookies between redirects - should be handled by LOCK transparently - should be handled by OPTIONS transparently - should log the redirection - should be handled by HEAD transparently - should be handled by POST transparently - options - should use body_stream when configured - should normalize base uri when specified as request option - should use basic auth when configured - digest_auth - should not send credentials more than once - should merge cookies from request and a 401 response - should maintain cookies returned from a 401 response - should not be used when configured and the response is 200 - should be used when configured and the response is 401 -HTTParty::Error - HTTParty::ResponseError - #ancestors - is expected to include HTTParty::Error - HTTParty::UnsupportedFormat - #ancestors - is expected to include HTTParty::Error - HTTParty::RedirectionTooDeep - #ancestors - is expected to include HTTParty::ResponseError - HTTParty::UnsupportedURIScheme - #ancestors - is expected to include HTTParty::Error - #ancestors - is expected to include StandardError - HTTParty::DuplicateLocationHeader - #ancestors - is expected to include HTTParty::ResponseError +HTTParty::CookieHash + #to_cookie_string + should not include SameSite attribute + should not include client side only cookies + should not mutate the hash + should format the key/value pairs, delimited by semi-colons + should not include client side only cookies even when attributes use camal case + #add_cookies + with a string + should add new key/value pairs to the hash + should handle '=' within cookie value + should handle an empty cookie parameter + should overwrite any existing key + with a hash + should add new key/value pairs to the hash + should overwrite any existing key + with other class + should error HTTParty::Response - does raise an error about itself when invoking a method that does not exist does raise an error about itself when using #method - responds to body + response to request + should send missing methods to delegate allows headers to be accessed by mixed-case names in hash notation + responds to predicates responds to headers - response to request - returns a comma-delimited value when multiple values exist responds to response - responds to anything parsed_response responds to - returns response headers + responds to body responds to parsed_response - should send missing methods to delegate + returns response headers + returns a comma-delimited value when multiple values exist + responds to anything parsed_response responds to responds to hash methods - responds to predicates - .underscore - works with all caps - works with titlecase - works with one capitalized word - #is_a? + does raise an error about itself when invoking a method that does not exist + #kind_of? + is expected to respond to #kind_of? with 1 argument is expected to be truthy is expected to be truthy - is expected to respond to #is_a? with 1 argument - headers - does equal a hash - does not equal itself when not equivalent - always equals itself - can initialize without headers - response is array - should display the same as an array - should be able to iterate - should respond to array methods - should equal the string response object body - #tap - is possible to tap into a response - marshalling - is expected to eq 200 semantic methods for response codes - major codes - is redirection - is success - is information - is server error - is client error for specific codes - responds to not_acceptable? - responds to method_not_allowed? - responds to created? - responds to accepted? - responds to moved_permanently? - responds to precondition_failed? - responds to switch_protocol? + responds to payload_too_large? + responds to request_timeout? responds to payment_required? - responds to gateway_time_out? + responds to created? + responds to expectation_failed? responds to gateway_timeout? - responds to multiple_choice? - responds to internal_server_error? - responds to request_entity_too_large? + responds to reset_content? + responds to precondition_failed? responds to see_other? - responds to not_implemented? + responds to found? + responds to method_not_allowed? + responds to requested_range_not_satisfiable? + responds to temporary_redirect? + responds to non_authoritative_information? + responds to not_modified? responds to gone? - responds to ok? responds to partial_content? - responds to request_uri_too_long? - responds to multiple_choices? - responds to bad_request? - responds to requested_range_not_satisfiable? responds to use_proxy? - responds to length_required? - responds to conflict? - responds to not_modified? - responds to service_unavailable? - responds to payload_too_large? - responds to expectation_failed? - responds to no_content? - responds to forbidden? - responds to reset_content? - responds to range_not_satisfiable? - responds to non_authoritative_information? - responds to found? responds to continue? responds to request_time_out? - responds to temporary_redirect? - responds to proxy_authentication_required? + responds to service_unavailable? responds to uri_too_long? + responds to moved_permanently? + responds to request_uri_too_long? + responds to accepted? + responds to forbidden? + responds to version_not_supported? + responds to ok? + responds to not_found? + responds to switch_protocol? + responds to proxy_authentication_required? + responds to no_content? + responds to length_required? + responds to internal_server_error? + responds to bad_request? + responds to multiple_choice? responds to unauthorized? + responds to range_not_satisfiable? + responds to request_entity_too_large? + responds to conflict? + responds to not_implemented? responds to bad_gateway? - responds to not_found? + responds to multiple_choices? + responds to not_acceptable? + responds to gateway_time_out? responds to unsupported_media_type? - responds to version_not_supported? - responds to request_timeout? - #inspect - works + major codes + is server error + is redirection + is client error + is success + is information + response is array + should respond to array methods + should be able to iterate + should display the same as an array + should equal the string response object body + #is_a? + is expected to be truthy + is expected to respond to #is_a? with 1 argument + is expected to be truthy + marshalling + is expected to eq 200 + .underscore + works with all caps + works with titlecase + works with one capitalized word + headers + always equals itself + does equal a hash + can initialize without headers + does not equal itself when not equivalent + #tap + is possible to tap into a response initialization - should set body - should set http_version + should set code as an Integer should set code + should set body should set the Net::HTTP Response - should set code as an Integer + should set http_version when raise_on is supplied - and response's status code is not in range - does not throw exception and response's status code is in range throws exception - #kind_of? - is expected to respond to #kind_of? with 1 argument - is expected to be truthy - is expected to be truthy + and response's status code is not in range + does not throw exception + #inspect + works + +HTTParty::Parser + .call + generates an HTTParty::Parser instance with the given body and format + calls #parse on the parser + .supports_format? + returns true for a supported format + returns false for an unsupported format + #parse + attempts to parse supported formats + returns the unparsed body when the format is unsupported + returns nil for an empty body + returns nil for a nil body + parses frozen strings + ignores utf-8 bom + parses ascii 8bit encoding + returns nil for a 'null' body + returns nil for a body with spaces only + does not raise exceptions for bodies with invalid encodings + .formats + returns the SupportedFormats constant + returns the SupportedFormats constant for subclasses + #supports_format? + utilizes the class method to determine if the format is supported + #parse_supported_format + calls the parser for the given format + when a parsing method does not exist for the given format + raises an exception + raises a useful exception message for subclasses + .format_from_mimetype + returns a symbol representing the format mimetype + returns nil when the mimetype is not supported + parsers + parses json with JSON + parses xml with MultiXml + parses html by simply returning the body + parses plain text by simply returning the body + parses csv with CSV + .SupportedFormats + returns a hash + .supported_formats + returns a unique set of supported formats represented by symbols + +HTTParty::Request + SSL certificate verification +# terminated with exception (report_on_exception is true): +/usr/lib/ruby/3.3.0/openssl/ssl.rb:527:in `accept': SSL_accept returned=1 errno=107 peeraddr=(null) state=error: tlsv1 alert unknown ca (SSL alert number 48) (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/3.3.0/openssl/ssl.rb:527: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.3.0/openssl/ssl.rb:527:in `accept': SSL_accept returned=1 errno=107 peeraddr=(null) state=error: tlsv1 alert unknown ca (SSL alert number 48) (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/3.3.0/openssl/ssl.rb:527: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 +# terminated with exception (report_on_exception is true): +/usr/lib/ruby/3.3.0/openssl/ssl.rb:527:in `accept': SSL_accept returned=1 errno=107 peeraddr=(null) state=error: tlsv1 alert unknown ca (SSL alert number 48) (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/3.3.0/openssl/ssl.rb:527:in `accept' + from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:56:in `thread_main' + from /build/reproducible-path/ruby-httparty-0.21.0/spec/support/ssl_test_server.rb:34:in `block (2 levels) in start' + should fail when no trusted CA list is specified, by default +# terminated with exception (report_on_exception is true): +/usr/lib/ruby/3.3.0/openssl/ssl.rb:527:in `accept': SSL_accept returned=1 errno=107 peeraddr=(null) state=error: tlsv1 alert unknown ca (SSL alert number 48) (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/3.3.0/openssl/ssl.rb:527: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 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.3.0/openssl/ssl.rb:527:in `accept': SSL_accept returned=1 errno=107 peeraddr=(null) state=error: ssl/tls alert bad certificate (SSL alert number 42) (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/3.3.0/openssl/ssl.rb:527: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.3.0/openssl/ssl.rb:527:in `accept': SSL_accept returned=1 errno=107 peeraddr=(null) state=error: tlsv1 alert unknown ca (SSL alert number 48) (OpenSSL::SSL::SSLError) + from /usr/lib/ruby/3.3.0/openssl/ssl.rb:527: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 + should work when using ssl_ca_file with a self-signed CA + should work when using ssl_ca_path with a certificate authority + should work when no trusted CA list is specified, when the verify option is set to false + +HTTParty::Decompressor + .SupportedEncodings + returns a hash + #decompress + when encoding is nil + 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 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 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 included + is expected to eq "foobar" + when ruby-lzws raises error + is expected to eq nil + when encoding is "none" + behaves like returns the body + is expected to eq "body" + when encoding is blank + behaves like returns the body + is expected to eq "body" + when body is nil + 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 body is blank + is expected to eq " " + +HTTParty::Logger + .build + builds :curl style logger + raises error when formatter exists + defaults level to :info + defaults format to :apache + builds :logstash style logger + builds :custom style logger + +HTTParty::Logger::CurlFormatter + #format + formats a response in a style that resembles a -v curl + when response is logged + logs headers + logs body + logs http version and response code + when request is logged + and headers are not present + not log Headers + and request's option 'base_uri' is not present + logs url + and request's option 'base_uri' is present + logs url + and query is not present + not logs Query + and query is present + logs query params + logs Query + when request raw_body is present + not logs request body + and headers are present + logs Headers + logs headers keys + +HTTParty::Request::Body + #multipart? + when params does not respond to to_hash + is expected to equal false + when params responds to to_hash + when it does not contain a file + is expected to eq false + when it contains file + is expected to equal true + when force_multipart is true + is expected to equal true + #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 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" + file object responds to original_filename + is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[avatar]\";...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" + when passing multipart as an option + is expected to eq "--------------------------c772861a5109d5ef\r\nContent-Disposition: form-data; name=\"user[first_name...: form-data; name=\"user[enabled]\"\r\n\r\ntrue\r\n--------------------------c772861a5109d5ef--\r\n" + +HTTParty::ResponseFragment + has access to delegators + access to fragment + +HTTParty::ConnectionAdapter + #connection + the resulting connection + is expected to be an instance of Net::HTTP + when 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 + https scheme with default port + is expected to use ssl + when ssl version is set + sets ssl version + https scheme with non-standard port + is expected to use ssl + should use the specified cert store, when one is given + is expected to use cert store # + using port 443 for ssl + is expected to use ssl + uses the system cert_store, by default + is expected to use cert store # + when timeout is not set and write_timeout is set to 8 seconds + should not set the open timeout + should not set the read timeout + #write_timeout + is expected to eq 8 + when timeout is not set and open_timeout is set to 7 seconds + should not set the read_timeout + should not set the write_timeout + #open_timeout + is expected to eq 7 + when timeout is set and open_timeout is set to 7 seconds + should override the timeout option + #write_timeout + is expected to eq 5 + #open_timeout + is expected to eq 7 + #read_timeout + is expected to eq 5 + when setting max_retries + to 0 times + #max_retries + is expected to eq 0 + to 5 times + #max_retries + is expected to eq 5 + and max_retries is a string + doesn't set the max_retries + when timeout is 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 + #open_timeout + is expected to eq 5 + #read_timeout + is expected to eq 6 + #write_timeout + is expected to eq 5 + 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 providing PEM certificates + when scheme is not https + has no PEM certificate + when scheme is https + will verify the certificate + uses the provided PEM certificate + when options include verify_peer=false + should not verify the certificate + when options include verify=false + should not verify the certificate + when timeout is not set and read_timeout is set to 6 seconds + should not set the write_timeout + should not set the open_timeout + #read_timeout + is expected to eq 6 + when setting 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 proxy address and port + is expected to be a proxy + #proxy_port + is expected to eq 8080 + #proxy_address + is expected to eq "1.2.3.4" + as well as proxy user and password + #proxy_user + is expected to eq "user" + #proxy_pass + is expected to eq "pass" + 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 debug_output + is set to $stderr + has debug output set + is not provided + does not set_debug_output + when dealing with IPv6 + strips brackets from the address + when providing nil as proxy address + is expected not to be a proxy + does pass nil proxy parameters to the connection, this forces to not use a proxy + when max_retries is not set + doesn't set the max_retries + when providing PKCS12 certificates + when scheme is https + uses the provided P12 certificate + will verify the certificate + when options include verify_peer=false + should not verify the certificate + when options include verify=false + should not verify the certificate + when scheme is not https + has no PKCS12 certificate + when 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 + .call + calls #connection on the connection adapter + generates an HTTParty::ConnectionAdapter instance with the given uri and options + initialization + takes a URI as input + sets the uri + raises an ArgumentError if the uri is a String + raises an ArgumentError if the uri is nil + sets the options + also accepts an optional options hash + +HTTParty + head requests should follow redirects requesting HEAD only + should remain HEAD request across redirects, unless specified otherwise + #resend_on_redirect + sets resend_on_redirect to true by default + sets resend_on_redirect option to false + .follow_redirects + sets the follow_redirects option to false + sets follow redirects to true by default + default params + should be able to be updated + should default to empty hash + two child classes inheriting from one parent + should dup the proc on the child class + works with lambda values + inherits default_cookies from the parent class + doesn't modify hashes in the parent's default options + doesn't modify the parent's default cookies + inherits default_options from the superclass + doesn't modify the parent's default options + does not modify each others inherited attributes + format + should only print each format once with an exception + sets the default parser + should allow csv + does not reset parser to the default parser + should allow xml + should not allow funky format + should allow plain + should allow json + connection_adapter + should not set the connection_adapter_options when not provided + should set the connection_adapter + should set the connection_adapter_options when provided + should process a request with a connection from the adapter + headers + overrides class headers with request headers + does not modify default_options when no arguments are passed + should be able to accept block as header value + should default to empty hash + uses the class headers when sending a request + should pass options as argument to header block value + should be able to be updated + merges class headers with request headers + when posting file + changes content-type headers to multipart/form-data + when headers passed as symbols + converts default headers to string + converts them to string + with cookies + adds optional cookies to the optional headers + adds cookies to the headers + utilizes the class-level cookies + doesnt modify default headers + ciphers + should set the ciphers content + #no_follow + sets the no_follow option to true + sets no_follow to false by default + parser + does not validate format whe custom parser is a proc + should be able parse response with custom parser + should set parser options + raises UnsupportedFormat when the parser cannot handle the format + pkcs12 + should set the password + should set the p12 content + #maintain_method_across_redirects + sets the maintain_method_across_redirects option to false + sets maintain_method_across_redirects to true by default + base uri + should have writer + should not modify the parameter during assignment + should have reader + .disable_rails_query_string_format + sets the query string normalizer to HTTParty::Request::NON_RAILS_QUERY_STRING_NORMALIZER + uri_adapter + with Addressable::URI + handles international domains + with custom URI Adaptor + should raise an ArgumentError if uri_adapter doesn't implement parse method + should process a request with a uri instance parsed from the uri_adapter + should set the uri_adapter + basic http authentication + should work + cookies + should raise an ArgumentError if passed a non-Hash + should allow a cookie to be specified with a one-off request + should not be in the headers by default + 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 allow the class defaults to be overridden + should include that cookie in the request + default timeout + should default to nil + should raise an exception if unsupported type provided + should support updating + should support floats + grand parent with inherited callback + continues running the #inherited on the parent + pem + should set the pem content + should set the password to nil if it's not provided + should set the password + #get + should be able parse response type csv 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 be able to get html + should be able to get chunked html + should not get undefined method add_node for nil class for the following xml + should return an empty body if stream_body option is turned on + should raise an InvalidURIError on URIs that can't be parsed at all + should accept https URIs + should accept http URIs + should accept webcal URIs + should be able parse response type json automatically + should be able parse response type xml automatically + when streaming body + is expected to eq # + .query_string_normalizer + sets the query_string_normalizer option + .raise_on + when parameters is an array + sets raise_on option + when parameters is a fixnum + sets raise_on option + with explicit override of automatic redirect handling + should fail with redirected PUT + should fail with redirected MOVE + should fail with redirected PATCH + should fail with redirected OPTIONS + should fail with redirected COPY + should fail with redirected DELETE + should fail with redirected HEAD + should fail with redirected MKCOL + should fail with redirected POST + should fail with redirected GET + #ensure_method_maintained_across_redirects + should not set maintain_method_across_redirects option if value is present + should set maintain_method_across_redirects option if unspecified + http_proxy + should set the proxy user and pass when they are provided + should set the address + with multiple class definitions + should not run over each others options + debug_output + stores the $stderr stream by default + stores the given stream as a default_option + .normalize_base_uri + should not treat uri's with a port of 4430 as ssl + should not modify the parameter + should not remove https for ssl requests + should add http if not present for non ssl requests + should add https if not present for ssl requests + ssl_version + should set the ssl_version content + digest http authentication + should work Pending: (Failures listed here are expected and do not affect your suite's status) @@ -2144,54 +2180,54 @@ # Temporarily skipped with xit # ./spec/httparty/request_spec.rb:691 -Top 10 slowest examples (1.22 seconds, 41.8% of total time): - HTTParty::Request SSL certificate verification should provide the certificate used by the server via peer_cert - 0.2203 seconds ./spec/httparty/ssl_spec.rb:74 - HTTParty::Request SSL certificate verification should work when using ssl_ca_file with a certificate authority - 0.15731 seconds ./spec/httparty/ssl_spec.rb:37 +Top 10 slowest examples (0.79303 seconds, 46.8% of total time): HTTParty::Request SSL certificate verification should work when using ssl_ca_file with a self-signed CA - 0.15545 seconds ./spec/httparty/ssl_spec.rb:33 - HTTParty connection_adapter should process a request with a connection from the adapter - 0.14024 seconds ./spec/httparty_spec.rb:495 - HTTParty::Request SSL certificate verification should work when no trusted CA list is specified, when the verify option is set to false - 0.13763 seconds ./spec/httparty/ssl_spec.rb:19 + 0.12819 seconds ./spec/httparty/ssl_spec.rb:33 + HTTParty::Request SSL certificate verification should work when using ssl_ca_file with a certificate authority + 0.12813 seconds ./spec/httparty/ssl_spec.rb:37 + HTTParty::Request SSL certificate verification should provide the certificate used by the server via peer_cert + 0.12788 seconds ./spec/httparty/ssl_spec.rb:74 HTTParty::Request SSL certificate verification should work when no trusted CA list is specified, even with a bogus hostname, when the verify option is set to true - 0.13609 seconds ./spec/httparty/ssl_spec.rb:29 + 0.11722 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.1172 seconds ./spec/httparty/ssl_spec.rb:19 HTTParty::Request::Body#call when params is hash when params has file is expected not to change `file.pos` - 0.09571 seconds ./spec/httparty/request/body_spec.rb:67 + 0.04438 seconds ./spec/httparty/request/body_spec.rb:67 HTTParty#get should be able parse response type xml automatically - 0.06215 seconds ./spec/httparty_spec.rb:907 - HTTParty::Request SSL certificate verification should fail when no trusted CA list is specified, with a bogus hostname, by default - 0.05731 seconds ./spec/httparty/ssl_spec.rb:23 - HTTParty::Request SSL certificate verification should fail when using ssl_ca_path and the server uses an unrecognized certificate authority - 0.05536 seconds ./spec/httparty/ssl_spec.rb:56 + 0.04356 seconds ./spec/httparty_spec.rb:907 + HTTParty::Request options should normalize base uri when specified as request option + 0.03008 seconds ./spec/httparty/request_spec.rb:248 + HTTParty::Request SSL certificate verification should fail when using ssl_ca_file and the server uses an unrecognized certificate authority + 0.02923 seconds ./spec/httparty/ssl_spec.rb:50 + HTTParty::Request SSL certificate verification should fail when using ssl_ca_file and the server uses a bogus hostname + 0.02716 seconds ./spec/httparty/ssl_spec.rb:62 Top 10 slowest example groups: HTTParty::Request - 0.09616 seconds average (1.15 seconds / 12 examples) ./spec/httparty/ssl_spec.rb:3 + 0.06611 seconds average (0.79328 seconds / 12 examples) ./spec/httparty/ssl_spec.rb:3 HTTParty::Request::Body - 0.00977 seconds average (0.10747 seconds / 11 examples) ./spec/httparty/request/body_spec.rb:6 - HTTParty::Logger - 0.00485 seconds average (0.02908 seconds / 6 examples) ./spec/httparty/logger/logger_spec.rb:3 + 0.00477 seconds average (0.05244 seconds / 11 examples) ./spec/httparty/request/body_spec.rb:6 HTTParty::ConnectionAdapter - 0.0044 seconds average (0.30767 seconds / 70 examples) ./spec/httparty/connection_adapter_spec.rb:3 - HTTParty - 0.00335 seconds average (0.39139 seconds / 117 examples) ./spec/httparty_spec.rb:3 - HTTParty::CookieHash - 0.00253 seconds average (0.03039 seconds / 12 examples) ./spec/httparty/cookie_hash_spec.rb:3 - HTTParty::Request - 0.00238 seconds average (0.66714 seconds / 280 examples) ./spec/httparty/request_spec.rb:3 + 0.00264 seconds average (0.18454 seconds / 70 examples) ./spec/httparty/connection_adapter_spec.rb:3 HTTParty::Logger::CurlFormatter - 0.00146 seconds average (0.01897 seconds / 13 examples) ./spec/httparty/logger/curl_formatter_spec.rb:3 - HTTParty::Parser - 0.00132 seconds average (0.03841 seconds / 29 examples) ./spec/httparty/parser_spec.rb:3 + 0.00177 seconds average (0.02304 seconds / 13 examples) ./spec/httparty/logger/curl_formatter_spec.rb:3 + Net::HTTPHeader::DigestAuthenticator + 0.00163 seconds average (0.05377 seconds / 33 examples) ./spec/httparty/net_digest_auth_spec.rb:3 + HTTParty::Request + 0.00126 seconds average (0.35279 seconds / 280 examples) ./spec/httparty/request_spec.rb:3 + HTTParty + 0.00113 seconds average (0.13251 seconds / 117 examples) ./spec/httparty_spec.rb:3 HTTParty::Logger::LogstashFormatter - 0.00106 seconds average (0.00106 seconds / 1 example) ./spec/httparty/logger/logstash_formatter_spec.rb:3 + 0.00099 seconds average (0.00099 seconds / 1 example) ./spec/httparty/logger/logstash_formatter_spec.rb:3 + HTTParty::Logger::ApacheFormatter + 0.00078 seconds average (0.00157 seconds / 2 examples) ./spec/httparty/logger/apache_formatter_spec.rb:3 + HTTParty::Decompressor + 0.00068 seconds average (0.01224 seconds / 18 examples) ./spec/httparty/decompressor_spec.rb:3 -Finished in 2.91 seconds (files took 1.1 seconds to load) +Finished in 1.69 seconds (files took 0.53371 seconds to load) 715 examples, 0 failures, 1 pending -Randomized with seed 26120 +Randomized with seed 26553 ┌──────────────────────────────────────────────────────────────────────────────┐ @@ -2231,12 +2267,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/2347295/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/2347295/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/3120442 and its subdirectories -I: Current time: Tue Mar 11 15:48:04 -12 2025 -I: pbuilder-time-stamp: 1741751284 +I: removing directory /srv/workspace/pbuilder/2347295 and its subdirectories +I: Current time: Wed Apr 15 00:11:55 +14 2026 +I: pbuilder-time-stamp: 1776161515