Spawner ready

Co-authored-by: Roberto Abdelkader Martínez Pérez <robertomartinezp@gmail.com>
This commit is contained in:
pancho horrillo
2019-10-10 11:49:03 +02:00
parent 958175c59a
commit a39e0f6605
4 changed files with 116 additions and 2 deletions
+13 -2
View File
@@ -5,18 +5,29 @@ import (
"os"
"os/exec"
"github.com/google/shlex"
"github.com/BBVA/kapow/internal/server/model"
)
func spawn(h *model.Handler, out io.Writer) error {
cmd := exec.Command(h.Route.Entrypoint)
args, err := shlex.Split(h.Route.Entrypoint)
if err != nil {
return err
}
if h.Route.Command != "" {
args = append(args, h.Route.Command)
}
cmd := exec.Command(args[0], args[1:]...)
if out != nil {
cmd.Stdout = out
}
cmd.Env = append(os.Environ(), "KAPOW_URL=http://localhost:8081")
cmd.Env = append(cmd.Env, "KAPOW_HANDLER_ID="+h.ID)
err := cmd.Run()
err = cmd.Run()
return err
}
+100
View File
@@ -5,6 +5,7 @@ import (
"encoding/json"
"log"
"os/exec"
"reflect"
"strings"
"testing"
@@ -123,3 +124,102 @@ func TestSpawnSetsKapowHandlerIDEnvVar(t *testing.T) {
t.Error("KAPOW_HANDLER_ID is not set properly")
}
}
func TestSpawnRunsOKEntrypointsWithAParam(t *testing.T) {
r := &model.Route{
Entrypoint: locateJailLover() + " -foo",
}
h := &model.Handler{
Route: r,
}
out := &bytes.Buffer{}
_ = spawn(h, out)
jldata := decodeJailLover(out.Bytes())
if !reflect.DeepEqual(jldata.Cmdline, []string{locateJailLover(), "-foo"}) {
t.Error("Args not as expected")
}
}
func TestSpawnRunsOKEntrypointWithArgWithSpace(t *testing.T) {
r := &model.Route{
Entrypoint: locateJailLover() + ` "foo bar"`,
}
h := &model.Handler{
Route: r,
}
out := &bytes.Buffer{}
_ = spawn(h, out)
jldata := decodeJailLover(out.Bytes())
if !reflect.DeepEqual(jldata.Cmdline, []string{locateJailLover(), "foo bar"}) {
t.Error("Args not parsed as expected")
}
}
func TestSpawnErrorsWhenEntrypointIsInvalidShell(t *testing.T) {
r := &model.Route{
Entrypoint: locateJailLover() + ` "`,
}
h := &model.Handler{
Route: r,
}
out := &bytes.Buffer{}
err := spawn(h, out)
if err == nil {
t.Error("Invalid args not reported")
}
}
func TestSpawnRunsOKEntrypointWithMultipleArgs(t *testing.T) {
r := &model.Route{
Entrypoint: locateJailLover() + " foo bar",
}
h := &model.Handler{
Route: r,
}
out := &bytes.Buffer{}
_ = spawn(h, out)
jldata := decodeJailLover(out.Bytes())
if !reflect.DeepEqual(jldata.Cmdline, []string{locateJailLover(), "foo", "bar"}) {
t.Error("Args not parsed as expected")
}
}
func TestSpawnRunsOKEntrypointAndCommand(t *testing.T) {
r := &model.Route{
Entrypoint: locateJailLover() + " foo bar",
Command: "baz qux",
}
h := &model.Handler{
Route: r,
}
out := &bytes.Buffer{}
_ = spawn(h, out)
jldata := decodeJailLover(out.Bytes())
if !reflect.DeepEqual(jldata.Cmdline, []string{locateJailLover(), "foo", "bar", "baz qux"}) {
t.Error("Malformed cmdline")
}
}