Implement Run function for data server.
Co-authored-by: Hector Hurtado <hector.hurtado@bbva.com>
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
package data
|
package data
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
"github.com/gorilla/mux"
|
"github.com/gorilla/mux"
|
||||||
@@ -22,3 +23,28 @@ func configRouter(rs []routeSpec) (r *mux.Router) {
|
|||||||
func(w http.ResponseWriter, r *http.Request) { w.WriteHeader(http.StatusBadRequest) })
|
func(w http.ResponseWriter, r *http.Request) { w.WriteHeader(http.StatusBadRequest) })
|
||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func Run(bindAddr string) {
|
||||||
|
rs := []routeSpec{
|
||||||
|
// request
|
||||||
|
{"/handlers/{handlerID}/request/method", "GET", getRequestMethod},
|
||||||
|
{"/handlers/{handlerID}/request/host", "GET", getRequestHost},
|
||||||
|
{"/handlers/{handlerID}/request/path", "GET", getRequestPath},
|
||||||
|
{"/handlers/{handlerID}/request/matches/{name}", "GET", getRequestMatches},
|
||||||
|
{"/handlers/{handlerID}/request/params/{name}", "GET", getRequestParams},
|
||||||
|
{"/handlers/{handlerID}/request/headers/{name}", "GET", getRequestHeaders},
|
||||||
|
{"/handlers/{handlerID}/request/cookies/{name}", "GET", getRequestCookies},
|
||||||
|
{"/handlers/{handlerID}/request/form/{name}", "GET", getRequestForm},
|
||||||
|
{"/handlers/{handlerID}/request/files/{name}/filename", "GET", getRequestFileName},
|
||||||
|
{"/handlers/{handlerID}/request/files/{name}/content", "GET", getRequestFileContent},
|
||||||
|
{"/handlers/{handlerID}/request/body", "GET", getRequestBody},
|
||||||
|
|
||||||
|
// response
|
||||||
|
{"/handlers/{handlerID}/response/status", "PUT", lockResponseWriter(setResponseStatus)},
|
||||||
|
{"/handlers/{handlerID}/response/headers/name", "PUT", lockResponseWriter(setResponseHeaders)},
|
||||||
|
{"/handlers/{handlerID}/response/cookies/name", "PUT", lockResponseWriter(setResponseCookies)},
|
||||||
|
{"/handlers/{handlerID}/response/body", "PUT", lockResponseWriter(setResponseBody)},
|
||||||
|
{"/handlers/{handlerID}/response/stream", "PUT", lockResponseWriter(setResponseBody)},
|
||||||
|
}
|
||||||
|
log.Fatal(http.ListenAndServe(bindAddr, configRouter(rs)))
|
||||||
|
}
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ import (
|
|||||||
|
|
||||||
func TestConfigRouterReturnsRouterWithDecoratedRoutes(t *testing.T) {
|
func TestConfigRouterReturnsRouterWithDecoratedRoutes(t *testing.T) {
|
||||||
var handlerID string
|
var handlerID string
|
||||||
list := []routeSpec{
|
rs := []routeSpec{
|
||||||
{
|
{
|
||||||
"/handlers/{handlerID}/dummy",
|
"/handlers/{handlerID}/dummy",
|
||||||
"GET",
|
"GET",
|
||||||
@@ -21,7 +21,7 @@ func TestConfigRouterReturnsRouterWithDecoratedRoutes(t *testing.T) {
|
|||||||
}
|
}
|
||||||
Handlers = New()
|
Handlers = New()
|
||||||
Handlers.Add(&model.Handler{ID: "FOO"})
|
Handlers.Add(&model.Handler{ID: "FOO"})
|
||||||
m := configRouter(list)
|
m := configRouter(rs)
|
||||||
|
|
||||||
m.ServeHTTP(httptest.NewRecorder(), httptest.NewRequest("GET", "/handlers/FOO/dummy", nil))
|
m.ServeHTTP(httptest.NewRecorder(), httptest.NewRequest("GET", "/handlers/FOO/dummy", nil))
|
||||||
|
|
||||||
|
|||||||
@@ -1,23 +0,0 @@
|
|||||||
package server_test
|
|
||||||
|
|
||||||
import (
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
"github.com/BBVA/kapow/internal/server"
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestStartServerWhenInvalidBindAddrReturnsError(t *testing.T) {
|
|
||||||
|
|
||||||
err := server.StartServer("foo;bar", "", "", true)
|
|
||||||
if err == nil {
|
|
||||||
t.Errorf("Expected error not found")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestStartServerWhenInvalidPortNumberReturnsError(t *testing.T) {
|
|
||||||
|
|
||||||
err := server.StartServer("0.0.0.0:bar", "", "", true)
|
|
||||||
if err == nil {
|
|
||||||
t.Errorf("Expected error not found")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user