Spawner ready
Co-authored-by: Roberto Abdelkader Martínez Pérez <robertomartinezp@gmail.com>
This commit is contained in:
@@ -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
|
||||
}
|
||||
|
||||
@@ -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")
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user