terraform/command/graph_test.go

165 lines
3.7 KiB
Go
Raw Normal View History

2014-07-12 05:38:03 +02:00
package command
import (
2014-07-12 05:41:47 +02:00
"os"
2014-07-12 05:38:03 +02:00
"strings"
"testing"
"github.com/mitchellh/cli"
"github.com/zclconf/go-cty/cty"
"github.com/hashicorp/terraform/addrs"
"github.com/hashicorp/terraform/plans"
"github.com/hashicorp/terraform/states"
2014-07-12 05:38:03 +02:00
)
func TestGraph(t *testing.T) {
tmp, cwd := testCwd(t)
defer testFixCwd(t, tmp, cwd)
2014-07-12 05:38:03 +02:00
ui := new(cli.MockUi)
c := &GraphCommand{
Meta: Meta{
testingOverrides: metaOverridesForProvider(testProvider()),
Ui: ui,
},
2014-07-12 05:38:03 +02:00
}
args := []string{
testFixturePath("graph"),
}
if code := c.Run(args); code != 0 {
t.Fatalf("bad: \n%s", ui.ErrorWriter.String())
}
output := ui.OutputWriter.String()
if !strings.Contains(output, "provider.test") {
2014-07-12 05:38:03 +02:00
t.Fatalf("doesn't look like digraph: %s", output)
}
}
2014-07-12 05:41:47 +02:00
func TestGraph_multipleArgs(t *testing.T) {
2014-07-12 05:38:03 +02:00
ui := new(cli.MockUi)
2014-07-13 04:47:31 +02:00
c := &GraphCommand{
Meta: Meta{
testingOverrides: metaOverridesForProvider(testProvider()),
Ui: ui,
},
2014-07-12 05:38:03 +02:00
}
2014-07-12 05:41:47 +02:00
args := []string{
"bad",
"bad",
}
2014-07-12 05:38:03 +02:00
if code := c.Run(args); code != 1 {
t.Fatalf("bad: \n%s", ui.OutputWriter.String())
}
}
2014-07-12 05:41:47 +02:00
func TestGraph_noArgs(t *testing.T) {
cwd, err := os.Getwd()
if err != nil {
t.Fatalf("err: %s", err)
}
if err := os.Chdir(testFixturePath("graph")); err != nil {
t.Fatalf("err: %s", err)
}
defer os.Chdir(cwd)
2014-07-12 05:38:03 +02:00
ui := new(cli.MockUi)
2014-07-12 05:41:47 +02:00
c := &GraphCommand{
Meta: Meta{
testingOverrides: metaOverridesForProvider(testProvider()),
Ui: ui,
},
2014-07-12 05:38:03 +02:00
}
2014-07-12 05:41:47 +02:00
args := []string{}
if code := c.Run(args); code != 0 {
t.Fatalf("bad: \n%s", ui.ErrorWriter.String())
2014-07-12 05:38:03 +02:00
}
2014-07-12 05:41:47 +02:00
output := ui.OutputWriter.String()
if !strings.Contains(output, "provider.test") {
2014-07-12 05:41:47 +02:00
t.Fatalf("doesn't look like digraph: %s", output)
2014-07-12 05:38:03 +02:00
}
}
2014-07-13 04:25:50 +02:00
func TestGraph_noConfig(t *testing.T) {
td := tempDir(t)
os.MkdirAll(td, 0755)
defer os.RemoveAll(td)
defer testChdir(t, td)()
ui := new(cli.MockUi)
c := &GraphCommand{
Meta: Meta{
testingOverrides: metaOverridesForProvider(testProvider()),
Ui: ui,
},
}
// Running the graph command without a config should not panic,
// but this may be an error at some point in the future.
args := []string{"-type", "apply"}
if code := c.Run(args); code != 0 {
t.Fatalf("bad: \n%s", ui.ErrorWriter.String())
}
}
2014-07-13 04:25:50 +02:00
func TestGraph_plan(t *testing.T) {
tmp, cwd := testCwd(t)
defer testFixCwd(t, tmp, cwd)
plan := &plans.Plan{
Changes: plans.NewChanges(),
}
plan.Changes.Resources = append(plan.Changes.Resources, &plans.ResourceInstanceChangeSrc{
Addr: addrs.Resource{
Mode: addrs.ManagedResourceMode,
Type: "test_instance",
Name: "bar",
}.Instance(addrs.NoKey).Absolute(addrs.RootModuleInstance),
ChangeSrc: plans.ChangeSrc{
Action: plans.Delete,
Before: plans.DynamicValue(`{}`),
After: plans.DynamicValue(`null`),
2016-12-04 00:00:34 +01:00
},
ProviderAddr: addrs.ProviderConfig{Type: addrs.NewLegacyProvider("test")}.Absolute(addrs.RootModuleInstance),
2014-07-13 04:25:50 +02:00
})
emptyConfig, err := plans.NewDynamicValue(cty.EmptyObjectVal, cty.EmptyObject)
if err != nil {
t.Fatal(err)
}
plan.Backend = plans.Backend{
// Doesn't actually matter since we aren't going to activate the backend
// for this command anyway, but we need something here for the plan
// file writer to succeed.
Type: "placeholder",
Config: emptyConfig,
}
_, configSnap := testModuleWithSnapshot(t, "graph")
planPath := testPlanFile(t, configSnap, states.NewState(), plan)
2014-07-13 04:25:50 +02:00
ui := new(cli.MockUi)
c := &GraphCommand{
Meta: Meta{
testingOverrides: metaOverridesForProvider(testProvider()),
Ui: ui,
},
2014-07-13 04:25:50 +02:00
}
args := []string{
planPath,
}
if code := c.Run(args); code != 0 {
t.Fatalf("bad: \n%s", ui.ErrorWriter.String())
}
output := ui.OutputWriter.String()
if !strings.Contains(output, "provider.test") {
2014-07-13 04:25:50 +02:00
t.Fatalf("doesn't look like digraph: %s", output)
}
}