2013-11-18 20:05:05 -05:00
|
|
|
package engine
|
|
|
|
|
|
|
|
import (
|
2014-02-15 18:06:21 -05:00
|
|
|
"bytes"
|
2013-11-20 02:38:59 -05:00
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
|
|
|
"path"
|
2014-02-15 17:27:01 -05:00
|
|
|
"path/filepath"
|
2014-02-24 15:06:08 -05:00
|
|
|
"strings"
|
2013-11-18 20:05:05 -05:00
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestRegister(t *testing.T) {
|
|
|
|
if err := Register("dummy1", nil); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := Register("dummy1", nil); err == nil {
|
|
|
|
t.Fatalf("Expecting error, got none")
|
|
|
|
}
|
2014-02-24 15:26:56 -05:00
|
|
|
// Register is global so let's cleanup to avoid conflicts
|
|
|
|
defer unregister("dummy1")
|
2013-11-18 20:05:05 -05:00
|
|
|
|
|
|
|
eng := newTestEngine(t)
|
|
|
|
|
2013-12-24 19:37:00 -05:00
|
|
|
//Should fail because global handlers are copied
|
2013-11-18 20:05:05 -05:00
|
|
|
//at the engine creation
|
|
|
|
if err := eng.Register("dummy1", nil); err == nil {
|
|
|
|
t.Fatalf("Expecting error, got none")
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := eng.Register("dummy2", nil); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := eng.Register("dummy2", nil); err == nil {
|
|
|
|
t.Fatalf("Expecting error, got none")
|
|
|
|
}
|
2014-02-24 15:26:56 -05:00
|
|
|
defer unregister("dummy2")
|
2013-11-18 20:05:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestJob(t *testing.T) {
|
|
|
|
eng := newTestEngine(t)
|
|
|
|
job1 := eng.Job("dummy1", "--level=awesome")
|
|
|
|
|
|
|
|
if job1.handler != nil {
|
|
|
|
t.Fatalf("job1.handler should be empty")
|
|
|
|
}
|
|
|
|
|
2013-11-20 02:37:03 -05:00
|
|
|
h := func(j *Job) Status {
|
|
|
|
j.Printf("%s\n", j.Name)
|
|
|
|
return 42
|
2013-11-18 20:05:05 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
eng.Register("dummy2", h)
|
2014-02-24 15:26:56 -05:00
|
|
|
defer unregister("dummy2")
|
2013-11-18 20:05:05 -05:00
|
|
|
job2 := eng.Job("dummy2", "--level=awesome")
|
|
|
|
|
|
|
|
if job2.handler == nil {
|
|
|
|
t.Fatalf("job2.handler shouldn't be nil")
|
|
|
|
}
|
|
|
|
|
2013-11-20 02:37:03 -05:00
|
|
|
if job2.handler(job2) != 42 {
|
2013-11-18 20:05:05 -05:00
|
|
|
t.Fatalf("handler dummy2 was not found in job2")
|
|
|
|
}
|
|
|
|
}
|
2013-11-20 02:38:59 -05:00
|
|
|
|
2014-02-15 18:06:21 -05:00
|
|
|
func TestEngineCommands(t *testing.T) {
|
|
|
|
eng := newTestEngine(t)
|
|
|
|
defer os.RemoveAll(eng.Root())
|
|
|
|
handler := func(job *Job) Status { return StatusOK }
|
|
|
|
eng.Register("foo", handler)
|
|
|
|
eng.Register("bar", handler)
|
|
|
|
eng.Register("echo", handler)
|
|
|
|
eng.Register("die", handler)
|
|
|
|
var output bytes.Buffer
|
|
|
|
commands := eng.Job("commands")
|
|
|
|
commands.Stdout.Add(&output)
|
|
|
|
commands.Run()
|
|
|
|
expected := "bar\ncommands\ndie\necho\nfoo\n"
|
|
|
|
if result := output.String(); result != expected {
|
|
|
|
t.Fatalf("Unexpected output:\nExpected = %v\nResult = %v\n", expected, result)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-11-20 02:38:59 -05:00
|
|
|
func TestEngineRoot(t *testing.T) {
|
|
|
|
tmp, err := ioutil.TempDir("", "docker-test-TestEngineCreateDir")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
defer os.RemoveAll(tmp)
|
2014-02-15 17:27:01 -05:00
|
|
|
// We expect Root to resolve to an absolute path.
|
|
|
|
// FIXME: this should not be necessary.
|
|
|
|
// Until the above FIXME is implemented, let's check for the
|
|
|
|
// current behavior.
|
|
|
|
tmp, err = filepath.EvalSymlinks(tmp)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
tmp, err = filepath.Abs(tmp)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2013-11-20 02:38:59 -05:00
|
|
|
dir := path.Join(tmp, "dir")
|
|
|
|
eng, err := New(dir)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if st, err := os.Stat(dir); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
} else if !st.IsDir() {
|
|
|
|
t.Fatalf("engine.New() created something other than a directory at %s", dir)
|
|
|
|
}
|
|
|
|
if r := eng.Root(); r != dir {
|
|
|
|
t.Fatalf("Expected: %v\nReceived: %v", dir, r)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestEngineString(t *testing.T) {
|
|
|
|
eng1 := newTestEngine(t)
|
|
|
|
defer os.RemoveAll(eng1.Root())
|
|
|
|
eng2 := newTestEngine(t)
|
|
|
|
defer os.RemoveAll(eng2.Root())
|
|
|
|
s1 := eng1.String()
|
|
|
|
s2 := eng2.String()
|
|
|
|
if eng1 == eng2 {
|
|
|
|
t.Fatalf("Different engines should have different names (%v == %v)", s1, s2)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestEngineLogf(t *testing.T) {
|
|
|
|
eng := newTestEngine(t)
|
|
|
|
defer os.RemoveAll(eng.Root())
|
|
|
|
input := "Test log line"
|
|
|
|
if n, err := eng.Logf("%s\n", input); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
} else if n < len(input) {
|
|
|
|
t.Fatalf("Test: Logf() should print at least as much as the input\ninput=%d\nprinted=%d", len(input), n)
|
|
|
|
}
|
|
|
|
}
|
2014-02-24 15:06:08 -05:00
|
|
|
|
|
|
|
func TestParseJob(t *testing.T) {
|
|
|
|
eng := newTestEngine(t)
|
|
|
|
defer os.RemoveAll(eng.Root())
|
|
|
|
// Verify that the resulting job calls to the right place
|
|
|
|
var called bool
|
|
|
|
eng.Register("echo", func(job *Job) Status {
|
|
|
|
called = true
|
|
|
|
return StatusOK
|
|
|
|
})
|
|
|
|
input := "echo DEBUG=1 hello world VERBOSITY=42"
|
|
|
|
job, err := eng.ParseJob(input)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if job.Name != "echo" {
|
|
|
|
t.Fatalf("Invalid job name: %v", job.Name)
|
|
|
|
}
|
|
|
|
if strings.Join(job.Args, ":::") != "hello:::world" {
|
|
|
|
t.Fatalf("Invalid job args: %v", job.Args)
|
|
|
|
}
|
|
|
|
if job.Env().Get("DEBUG") != "1" {
|
|
|
|
t.Fatalf("Invalid job env: %v", job.Env)
|
|
|
|
}
|
|
|
|
if job.Env().Get("VERBOSITY") != "42" {
|
|
|
|
t.Fatalf("Invalid job env: %v", job.Env)
|
|
|
|
}
|
|
|
|
if len(job.Env().Map()) != 2 {
|
|
|
|
t.Fatalf("Invalid job env: %v", job.Env)
|
|
|
|
}
|
|
|
|
if err := job.Run(); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if !called {
|
|
|
|
t.Fatalf("Job was not called")
|
|
|
|
}
|
|
|
|
}
|