Created
September 30, 2017 16:05
-
-
Save gsingharoy/f9b9dd46b5486f24178e473cfbd8f22e to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package main | |
import ( | |
"net/http" | |
"net/http/httptest" | |
"testing" | |
"github.com/julienschmidt/httprouter" | |
) | |
func TestBookIndex(t *testing.T) { | |
// Create an entry of the book to the bookstore map | |
testBook := &Book{ | |
ISDN: "111", | |
Title: "test title", | |
Author: "test author", | |
Pages: 42, | |
} | |
bookstore["111"] = testBook | |
// A request with an existing isdn | |
req1, err := http.NewRequest("GET", "/books", nil) | |
if err != nil { | |
t.Fatal(err) | |
} | |
rr1 := newRequestRecorder(req1, "GET", "/books", BookIndex) | |
if rr1.Code != 200 { | |
t.Error("Expected response code to be 200") | |
} | |
// expected response | |
er1 := "{\"meta\":null,\"data\":[{\"isdn\":\"111\",\"title\":\"test title\",\"author\":\"test author\",\"pages\":42}]}\n" | |
if rr1.Body.String() != er1 { | |
t.Error("Response body does not match") | |
} | |
} | |
// Mocks a handler and returns a httptest.ResponseRecorder | |
func newRequestRecorder(req *http.Request, method string, strPath string, fnHandler func(w http.ResponseWriter, r *http.Request, param httprouter.Params)) *httptest.ResponseRecorder { | |
router := httprouter.New() | |
router.Handle(method, strPath, fnHandler) | |
// We create a ResponseRecorder (which satisfies http.ResponseWriter) to record the response. | |
rr := httptest.NewRecorder() | |
// Our handlers satisfy http.Handler, so we can call their ServeHTTP method | |
// directly and pass in our Request and ResponseRecorder. | |
router.ServeHTTP(rr, req) | |
return rr | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment