|
1 | 1 | package controller |
2 | 2 |
|
3 | 3 | import ( |
| 4 | + "errors" |
4 | 5 | "fmt" |
5 | 6 | "io/ioutil" |
6 | 7 | "os" |
| 8 | + "path/filepath" |
7 | 9 | "testing" |
8 | 10 |
|
| 11 | + builderconf "github.com/deis/builder/pkg/conf" |
| 12 | + |
9 | 13 | "github.com/arschles/assert" |
| 14 | + deis "github.com/deis/controller-sdk-go" |
10 | 15 | ) |
11 | 16 |
|
12 | | -func TestGetControllerClient(t *testing.T) { |
| 17 | +func TestNew(t *testing.T) { |
13 | 18 | tmpDir, err := ioutil.TempDir("", "tmpdir") |
14 | 19 | if err != nil { |
15 | 20 | t.Fatalf("error creating temp directory (%s)", err) |
16 | 21 | } |
17 | | - data := []byte("testbuilderkey") |
18 | | - if err := ioutil.WriteFile(tmpDir+"/builder-key", data, 0644); err != nil { |
19 | | - t.Fatalf("error creating %s/builder-key (%s)", tmpDir, err) |
20 | | - } |
| 22 | + |
21 | 23 | defer func() { |
22 | 24 | if err := os.RemoveAll(tmpDir); err != nil { |
23 | 25 | t.Fatalf("failed to remove builder-key from %s (%s)", tmpDir, err) |
24 | 26 | } |
25 | 27 | }() |
| 28 | + |
| 29 | + builderconf.BuilderKeyLocation = filepath.Join(tmpDir, "builder-key") |
| 30 | + data := []byte("testbuilderkey") |
| 31 | + if err := ioutil.WriteFile(builderconf.BuilderKeyLocation, data, 0644); err != nil { |
| 32 | + t.Fatalf("error creating %s (%s)", builderconf.BuilderKeyLocation, err) |
| 33 | + } |
| 34 | + |
26 | 35 | host := "127.0.0.1" |
27 | 36 | port := "80" |
28 | | - cli, err := New(host, port, tmpDir+"/builder-key") |
| 37 | + cli, err := New(host, port) |
29 | 38 | assert.NoErr(t, err) |
30 | 39 | assert.Equal(t, cli.ControllerURL.String(), fmt.Sprintf("http://%s:%s/", host, port), "data") |
31 | 40 | assert.Equal(t, cli.HooksToken, string(data), "data") |
| 41 | + assert.Equal(t, cli.UserAgent, "deis-builder", "user-agent") |
| 42 | + |
| 43 | + port = "invalid-port-number" |
| 44 | + if _, err = New(host, port); err == nil { |
| 45 | + t.Errorf("expected error with invalid port number, got nil") |
| 46 | + } |
32 | 47 | } |
33 | 48 |
|
34 | | -func TestGetControllerClientError(t *testing.T) { |
| 49 | +func TestNewWithInvalidBuilderKeyPath(t *testing.T) { |
35 | 50 | host := "127.0.0.1" |
36 | 51 | port := "80" |
37 | | - _, err := New(host, port, "/builder-key") |
| 52 | + _, err := New(host, port) |
38 | 53 | assert.True(t, err != nil, "no error received when there should have been") |
39 | 54 | } |
| 55 | + |
| 56 | +func TestCheckAPICompat(t *testing.T) { |
| 57 | + client := &deis.Client{ControllerAPIVersion: deis.APIVersion} |
| 58 | + err := deis.ErrAPIMismatch |
| 59 | + |
| 60 | + if apiErr := CheckAPICompat(client, err); apiErr != nil { |
| 61 | + t.Errorf("api errors are non-fatal and should return nil, got '%v'", apiErr) |
| 62 | + } |
| 63 | + |
| 64 | + err = errors.New("random error") |
| 65 | + if apiErr := CheckAPICompat(client, err); apiErr == nil { |
| 66 | + t.Error("expected error to be returned, got nil") |
| 67 | + } |
| 68 | +} |
0 commit comments