defmodule HTTParrot.StreamHandlerTest do use ExUnit.Case, async: false import :meck import HTTParrot.StreamHandler setup do new(:cowboy_req) new(HTTParrot.GeneralRequestInfo) new(JSX) on_exit(fn -> unload() end) :ok end test "malformed_request returns true if it's not an integer" do expect(:cowboy_req, :binding, [{[:n, :req1], "a2B="}]) assert malformed_request(:req1, :state) == {true, :req1, :state} assert validate(:cowboy_req) end test "malformed_request returns false if it's an integer" do expect(:cowboy_req, :binding, [{[:n, :req1], "2"}]) assert malformed_request(:req1, :state) == {false, :req1, 2} assert validate(:cowboy_req) end test "malformed_request returns 1 if 'n' is less than 1" do expect(:cowboy_req, :binding, [{[:n, :req1], "0"}]) assert malformed_request(:req1, :state) == {false, :req1, 1} assert validate(:cowboy_req) end test "malformed_request returns 100 if 'n' is greater than 100" do expect(:cowboy_req, :binding, [{[:n, :req1], "200"}]) assert malformed_request(:req1, :state) == {false, :req1, 100} assert validate(:cowboy_req) end test "response must stream chunks" do expect(HTTParrot.GeneralRequestInfo, :retrieve, 1, {[:info], :req2}) expect(JSX, :encode!, [{[[{:id, 0}, :info]], :json1}, {[[{:id, 1}, :info]], :json2}]) assert {{:chunked, func}, :req2, nil} = get_json(:req1, 2) assert is_function(func) send_func = fn body -> send(self(), {:chunk, body}) end func.(send_func) assert_receive {:chunk, :json1} assert_receive {:chunk, :json2} assert validate(HTTParrot.GeneralRequestInfo) assert validate(JSX) end end