1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110
|
# frozen_string_literal: true
# Released under the MIT License.
# Copyright, 2025, by Samuel Williams.
require "protocol/http/header/transfer_encoding"
describe Protocol::HTTP::Header::TransferEncoding do
let(:header) {subject.parse(description)}
with "chunked" do
it "detects chunked encoding" do
expect(header).to be(:chunked?)
end
end
with "gzip" do
it "detects gzip encoding" do
expect(header).to be(:gzip?)
end
end
with "deflate" do
it "detects deflate encoding" do
expect(header).to be(:deflate?)
end
end
with "compress" do
it "detects compress encoding" do
expect(header).to be(:compress?)
end
end
with "identity" do
it "detects identity encoding" do
expect(header).to be(:identity?)
end
end
with "gzip, chunked" do
it "handles multiple encodings" do
expect(header.length).to be == 2
expect(header).to be(:include?, "gzip")
expect(header).to be(:include?, "chunked")
expect(header).to be(:gzip?)
expect(header).to be(:chunked?)
end
end
with "empty header value" do
let(:header) {subject.new}
it "handles empty transfer encoding" do
expect(header).to be(:empty?)
expect(header).not.to be(:chunked?)
end
end
with "#<<" do
let(:header) {subject.new}
it "can add encodings" do
header << "gzip"
expect(header).to be(:gzip?)
header << "chunked"
expect(header).to be(:chunked?)
end
end
with ".trailer?" do
it "should be forbidden in trailers" do
expect(subject).not.to be(:trailer?)
end
end
with ".coerce" do
it "normalizes array values to lowercase" do
header = subject.coerce(["GZIP", "CHUNKED"])
expect(header).to be(:include?, "gzip")
expect(header).to be(:include?, "chunked")
expect(header).not.to be(:include?, "GZIP")
end
it "normalizes string values to lowercase" do
header = subject.coerce("GZIP, CHUNKED")
expect(header).to be(:include?, "gzip")
expect(header).to be(:include?, "chunked")
end
end
with ".new" do
it "preserves case when given array" do
header = subject.new(["GZIP", "CHUNKED"])
expect(header).to be(:include?, "GZIP")
expect(header).to be(:include?, "CHUNKED")
end
it "normalizes when given string (backward compatibility)" do
header = subject.new("GZIP, CHUNKED")
expect(header).to be(:include?, "gzip")
expect(header).to be(:include?, "chunked")
end
it "raises ArgumentError for invalid value types" do
expect{subject.new(123)}.to raise_exception(ArgumentError)
end
end
end
|