Skip to content

Commit

Permalink
Satisfy IO#readpartial API
Browse files Browse the repository at this point in the history
IO#readpartial allows for a second "outbuf" param which some streaming usages
expect, so support it here to allow using response bodies anywhere IO can be.
  • Loading branch information
singpolyma-shopify committed Aug 24, 2020
1 parent a0f540f commit 3c1132c
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 2 deletions.
5 changes: 3 additions & 2 deletions lib/http/connection.rb
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ def send_request(req)
#
# @return [String] data chunk
# @return [nil] when no more data left
def readpartial(size = BUFFER_SIZE)
def readpartial(size = BUFFER_SIZE, outbuf = nil)
return unless @pending_response

chunk = @parser.read(size)
Expand All @@ -93,7 +93,8 @@ def readpartial(size = BUFFER_SIZE)
chunk = @parser.read(size)
finish_response if finished

chunk || "".b
chunk ||= "".b
outbuf ? outbuf.replace(chunk) : chunk
end

# Reads data from socket up until headers are loaded
Expand Down
10 changes: 10 additions & 0 deletions spec/lib/http/connection_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -62,5 +62,15 @@
end
expect(buffer).to eq "1234567890"
end

it "fill outbuf when present" do
connection.read_headers!
outbuf = String.new
buffer = String.new
while connection.readpartial(3, outbuf)
buffer << outbuf
end
expect(buffer).to eq "1234567890"
end
end
end

0 comments on commit 3c1132c

Please sign in to comment.