Files
kapow/internal/client/set_test.go
pancho horrillo 0b056f6cf0 internal/client/{get,set}_test.go: send io.Writer() based on []byte
* internal/client/get_test.go:
  - Revert changes when setting the Body of the mock (gock).
  - Revert over-eager line splitting.

* internal/client/set_test.go:
  - Use bytes.NewReader([]byte("200")) instead of strings.NewReader("200")

Thanks to @nilp0inter for the feedback!
2019-10-06 11:34:15 +02:00

56 lines
1.2 KiB
Go

package client_test
import (
"bytes"
"net/http"
"testing"
gock "gopkg.in/h2non/gock.v1"
"github.com/BBVA/kapow/internal/client"
)
// Test an HTTP OK request
func TestSetDataSuccessOnCorrectRequest(t *testing.T) {
defer gock.Off()
gock.New("http://localhost:8080").
Put("/HANDLER_FOO/response/status/code").
Reply(http.StatusOK)
if err := client.SetData(
"http://localhost:8080",
"HANDLER_FOO",
"/response/status/code",
bytes.NewReader([]byte("200")),
); err != nil {
t.Error("Unexpected error")
}
if !gock.IsDone() {
t.Errorf("No endpoint called")
}
}
// Test that Not Found errors are detected when an invalid handler id is sent
func TestSetDataErrIfBadHandlerID(t *testing.T) {
defer gock.Off()
gock.New("http://localhost:8080").
Put("/HANDLER_BAD/response/status/code").
Reply(http.StatusNotFound)
if err := client.SetData(
"http://localhost:8080",
"HANDLER_BAD",
"/response/status/code",
bytes.NewReader([]byte("200")),
); err == nil {
t.Error("Expected error not present")
} else if err.Error() != "Not Found" {
t.Errorf(`Error mismatch: expected "Not Found", got %q`, err)
}
if !gock.IsDone() {
t.Errorf("No endpoint called")
}
}