mirror of
https://github.com/fnproject/fn.git
synced 2022-10-28 21:29:17 +03:00
152 lines
3.4 KiB
Go
152 lines
3.4 KiB
Go
package protocol
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/json"
|
|
"io"
|
|
"io/ioutil"
|
|
"net/http"
|
|
"net/url"
|
|
"reflect"
|
|
"testing"
|
|
|
|
"github.com/fnproject/fn/api/models"
|
|
)
|
|
|
|
type RequestData struct {
|
|
A string `json:"a"`
|
|
}
|
|
|
|
func setupRequest(data interface{}) *http.Request {
|
|
req := &http.Request{
|
|
Method: http.MethodPost,
|
|
URL: &url.URL{
|
|
Scheme: "http",
|
|
Host: "localhost:8080",
|
|
Path: "/v1/apps",
|
|
RawQuery: "something=something&etc=etc",
|
|
},
|
|
ProtoMajor: 1,
|
|
ProtoMinor: 1,
|
|
Header: http.Header{
|
|
"Host": []string{"localhost:8080"},
|
|
"User-Agent": []string{"curl/7.51.0"},
|
|
"Content-Type": []string{"application/json"},
|
|
},
|
|
Host: "localhost:8080",
|
|
}
|
|
var buf bytes.Buffer
|
|
|
|
if data != nil {
|
|
_ = json.NewEncoder(&buf).Encode(data)
|
|
}
|
|
req.Body = ioutil.NopCloser(&buf)
|
|
return req
|
|
}
|
|
|
|
func TestJSONProtocolwriteJSONInputRequestWithData(t *testing.T) {
|
|
rDataBefore := RequestData{A: "a"}
|
|
req := setupRequest(rDataBefore)
|
|
r, w := io.Pipe()
|
|
call := &models.Call{Type: "json"}
|
|
ci := &callInfoImpl{call, req}
|
|
proto := JSONProtocol{w, r}
|
|
go func() {
|
|
err := proto.writeJSONToContainer(ci)
|
|
if err != nil {
|
|
t.Error(err.Error())
|
|
}
|
|
w.Close()
|
|
}()
|
|
incomingReq := &jsonIn{}
|
|
bb := new(bytes.Buffer)
|
|
|
|
_, err := bb.ReadFrom(r)
|
|
if err != nil {
|
|
t.Error(err.Error())
|
|
}
|
|
err = json.Unmarshal(bb.Bytes(), incomingReq)
|
|
if err != nil {
|
|
t.Error(err.Error())
|
|
}
|
|
rDataAfter := new(RequestData)
|
|
err = json.Unmarshal([]byte(incomingReq.Body), &rDataAfter)
|
|
if err != nil {
|
|
t.Error(err.Error())
|
|
}
|
|
if rDataBefore.A != rDataAfter.A {
|
|
t.Errorf("Request data assertion mismatch: expected: %s, got %s",
|
|
rDataBefore.A, rDataAfter.A)
|
|
}
|
|
if incomingReq.Protocol.Type != call.Type {
|
|
t.Errorf("Call protocol type assertion mismatch: expected: %s, got %s",
|
|
call.Type, incomingReq.Protocol.Type)
|
|
}
|
|
}
|
|
|
|
func TestJSONProtocolwriteJSONInputRequestWithoutData(t *testing.T) {
|
|
req := setupRequest(nil)
|
|
|
|
call := &models.Call{Type: "json"}
|
|
r, w := io.Pipe()
|
|
ci := &callInfoImpl{call, req}
|
|
proto := JSONProtocol{w, r}
|
|
go func() {
|
|
err := proto.writeJSONToContainer(ci)
|
|
if err != nil {
|
|
t.Error(err.Error())
|
|
}
|
|
w.Close()
|
|
}()
|
|
incomingReq := &jsonIn{}
|
|
bb := new(bytes.Buffer)
|
|
|
|
_, err := bb.ReadFrom(r)
|
|
if err != nil {
|
|
t.Error(err.Error())
|
|
}
|
|
err = json.Unmarshal(bb.Bytes(), incomingReq)
|
|
if err != nil {
|
|
t.Error(err.Error())
|
|
}
|
|
if incomingReq.Body != "" {
|
|
t.Errorf("Request body assertion mismatch: expected: %s, got %s",
|
|
"<empty-string>", incomingReq.Body)
|
|
}
|
|
if ok := reflect.DeepEqual(req.Header, incomingReq.Protocol.Headers); !ok {
|
|
t.Errorf("Request headers assertion mismatch: expected: %s, got %s",
|
|
req.Header, incomingReq.Protocol.Headers)
|
|
}
|
|
}
|
|
|
|
func TestJSONProtocolwriteJSONInputRequestWithQuery(t *testing.T) {
|
|
req := setupRequest(nil)
|
|
|
|
r, w := io.Pipe()
|
|
call := &models.Call{Type: "json"}
|
|
ci := &callInfoImpl{call, req}
|
|
proto := JSONProtocol{w, r}
|
|
go func() {
|
|
err := proto.writeJSONToContainer(ci)
|
|
if err != nil {
|
|
t.Error(err.Error())
|
|
}
|
|
w.Close()
|
|
}()
|
|
incomingReq := &jsonIn{}
|
|
bb := new(bytes.Buffer)
|
|
|
|
_, err := bb.ReadFrom(r)
|
|
if err != nil {
|
|
t.Error(err.Error())
|
|
}
|
|
err = json.Unmarshal(bb.Bytes(), incomingReq)
|
|
if err != nil {
|
|
t.Error(err.Error())
|
|
}
|
|
if incomingReq.Protocol.RequestURL != req.URL.RequestURI() {
|
|
t.Errorf("Request URL does not match protocol URL: expected: %s, got %s",
|
|
req.URL.RequestURI(), incomingReq.Protocol.RequestURL)
|
|
}
|
|
}
|