From aab3ac4dfe17e9eb82e39ac7ff322498f3b149fd Mon Sep 17 00:00:00 2001 From: Adnan Maolood Date: Thu, 18 Feb 2021 00:07:43 -0500 Subject: response: Implement Write method --- response_test.go | 42 +++++++++++++++++++++++++++++++++--------- 1 file changed, 33 insertions(+), 9 deletions(-) (limited to 'response_test.go') diff --git a/response_test.go b/response_test.go index ab2484f..889e1ab 100644 --- a/response_test.go +++ b/response_test.go @@ -6,13 +6,14 @@ import ( "testing" ) -func TestReadResponse(t *testing.T) { +func TestReadWriteResponse(t *testing.T) { tests := []struct { - Raw string - Status int - Meta string - Body string - Err error + Raw string + Status int + Meta string + Body string + Err error + SkipWrite bool }{ { Raw: "20 text/gemini\r\nHello, world!\nWelcome to my capsule.", @@ -31,9 +32,10 @@ func TestReadResponse(t *testing.T) { Meta: "/redirect", }, { - Raw: "31 /redirect\r\nThis body is ignored.", - Status: 31, - Meta: "/redirect", + Raw: "31 /redirect\r\nThis body is ignored.", + Status: 31, + Meta: "/redirect", + SkipWrite: true, // skip write test since result won't match Raw }, { Raw: "99 Unknown status code\r\n", @@ -100,4 +102,26 @@ func TestReadResponse(t *testing.T) { t.Errorf("expected body = %#v, got %#v", test.Body, body) } } + + for _, test := range tests { + if test.Err != nil || test.SkipWrite { + continue + } + resp := &Response{ + Status: test.Status, + Meta: test.Meta, + Body: io.NopCloser(strings.NewReader(test.Body)), + } + + var b strings.Builder + if err := resp.Write(&b); err != nil { + t.Error(err) + continue + } + + got := b.String() + if got != test.Raw { + t.Errorf("expected %#v, got %#v", test.Raw, got) + } + } } -- cgit v1.2.3