httpx/test/support/requests/plugins/compression.rb
HoneyryderChuck a2895d456f regression test for bug fixed in 0.11.3
created a test server which removes the content-length. Taken extra
condition into account, that the close might manifest itself while
selecting on the socket; at that point we're out of the consumption
loop, so better not to deal with throwing :called
2021-02-17 00:55:05 +00:00

132 lines
4.9 KiB
Ruby

# frozen_string_literal: true
module Requests
module Plugins
module Compression
def test_plugin_compression_accepts
url = "https://github.com"
response1 = HTTPX.get(url)
skip if response1.status == 429
verify_status(response1, 200)
assert !response1.headers.key?("content-encoding"), "response should come in plain text"
response1.close
session = HTTPX.plugin(:compression)
response = session.get(url)
skip if response == 429
verify_status(response, 200)
assert response.body.encodings == %w[gzip], "response should be sent with gzip encoding"
response.close
end
def test_plugin_compression_identity_post
session = HTTPX.plugin(:compression)
uri = build_uri("/post")
response = session.with_headers("content-encoding" => "identity")
.post(uri, body: "a" * 8012)
verify_status(response, 200)
body = json_body(response)
verify_header(body["headers"], "Content-Type", "application/octet-stream")
compressed_data = body["data"]
assert compressed_data.bytesize == 8012, "body shouldn't have been compressed"
end
def test_plugin_compression_gzip
session = HTTPX.plugin(:compression)
uri = build_uri("/gzip")
response = session.get(uri)
verify_status(response, 200)
body = json_body(response)
assert body["gzipped"], "response should be gzipped"
end
def test_plugin_compression_gzip_post
session = HTTPX.plugin(:compression)
uri = build_uri("/post")
response = session.with_headers("content-encoding" => "gzip")
.post(uri, body: "a" * 8012)
verify_status(response, 200)
body = json_body(response)
verify_header(body["headers"], "Content-Type", "application/octet-stream")
compressed_data = body["data"]
assert compressed_data.bytesize < 8012, "body hasn't been compressed"
end
def test_plugin_compression_gzip_post_threshold_size
session = HTTPX.plugin(:compression, compression_threshold_size: 8015)
uri = build_uri("/post")
response = session.with_headers("content-encoding" => "gzip")
.post(uri, body: "a" * 8012)
verify_status(response, 200)
body = json_body(response)
verify_header(body["headers"], "Content-Type", "application/octet-stream")
compressed_data = body["data"]
assert compressed_data.bytesize == 8012, "body has been compressed when it shouldn't"
end
def test_plugin_compression_deflate
session = HTTPX.plugin(:compression)
uri = build_uri("/deflate")
response = session.get(uri)
verify_status(response, 200)
body = json_body(response)
assert body["deflated"], "response should be deflated"
end
def test_plugin_compression_deflate_post
session = HTTPX.plugin(:compression)
uri = build_uri("/post")
response = session.with_headers("content-encoding" => "deflate")
.post(uri, body: "a" * 8012)
verify_status(response, 200)
body = json_body(response)
verify_header(body["headers"], "Content-Type", "application/octet-stream")
compressed_data = body["data"]
assert compressed_data.bytesize < 8012, "body hasn't been compressed"
end
# regression test
def test_plugin_compression_no_content_length
# run this only for http/1.1 mode, as this is a local test server
return unless origin.start_with?("http://")
server = NoContentLengthServer.new
th = Thread.new { server.start }
begin
http = HTTPX.plugin(:compression)
uri = build_uri("/", server.origin)
response = http.get(uri)
verify_status(response, 200)
body = response.body.to_s
assert body == "helloworld"
ensure
server.shutdown
th.join
end
end
unless RUBY_ENGINE == "jruby"
def test_plugin_compression_brotli
session = HTTPX.plugin(:"compression/brotli")
response = session.get("http://httpbin.org/brotli")
verify_status(response, 200)
body = json_body(response)
assert body["brotli"], "response should be deflated"
end
def test_plugin_compression_brotli_post
session = HTTPX.plugin(:"compression/brotli")
uri = build_uri("/post")
response = session.with_headers("content-encoding" => "br")
.post(uri, body: "a" * 8012)
verify_status(response, 200)
body = json_body(response)
verify_header(body["headers"], "Content-Type", "application/octet-stream")
compressed_data = body["data"]
assert compressed_data.bytesize < 8012, "body hasn't been compressed"
end
end
end
end
end