Files
kapow/internal/client/route_add_test.go
pancho horrillo f98784088d Normalize internal/client/*_test.go
* Adjust test style for easy reading, by using literals instead of vars
* Move comparison to the `bytes` domain, instead of `string`
* Simplify testing code by using bytes.Buffer directly
* More consistent naming of variables and dummies (HANDLE_{FOO,BAR,BAD})
* Consistent testing style of gock.IsDone()
* Stick to 80-column
2019-10-06 09:41:12 +02:00

40 lines
943 B
Go

package client
import (
"net/http"
"testing"
gock "gopkg.in/h2non/gock.v1"
)
func TestSuccessOnCorrectRoute(t *testing.T) {
defer gock.Off()
gock.New("http://localhost").
Put("/routes").
MatchType("json").
JSON(map[string]string{
"method": "GET",
"url_pattern": "/hello",
"entrypoint": "",
"command": "echo Hello World | kapow set /response/body",
}).
Reply(http.StatusCreated).
JSON(map[string]string{})
// TODO: As per the spec¹, the call should return a JSON body with the info
// of the newly created route. Should we consider this in the mocked server
// and in the test?
// ¹: https://github.com/BBVA/kapow/tree/master/spec#insert-a-route
err := AddRoute(
"http://localhost",
"/hello", "GET", "", "echo Hello World | kapow set /response/body", nil)
if err != nil {
t.Errorf("Unexpected error: %s", err)
}
if !gock.IsDone() {
t.Error("Expected endpoint call not made")
}
}