2015-03-05 05:42:26 +01:00
|
|
|
package command
|
|
|
|
|
|
|
|
import (
|
2015-03-05 23:55:15 +01:00
|
|
|
"archive/tar"
|
2015-03-06 23:49:22 +01:00
|
|
|
"bytes"
|
2015-03-05 23:55:15 +01:00
|
|
|
"compress/gzip"
|
|
|
|
"io"
|
|
|
|
"os"
|
|
|
|
"reflect"
|
|
|
|
"sort"
|
2015-03-05 05:42:26 +01:00
|
|
|
"testing"
|
|
|
|
|
2016-07-25 21:56:56 +02:00
|
|
|
atlas "github.com/hashicorp/atlas-go/v1"
|
2015-03-05 05:42:26 +01:00
|
|
|
"github.com/hashicorp/terraform/terraform"
|
|
|
|
"github.com/mitchellh/cli"
|
|
|
|
)
|
|
|
|
|
2015-03-05 23:55:15 +01:00
|
|
|
func TestPush_good(t *testing.T) {
|
|
|
|
tmp, cwd := testCwd(t)
|
|
|
|
defer testFixCwd(t, tmp, cwd)
|
|
|
|
|
|
|
|
// Create remote state file, this should be pulled
|
|
|
|
conf, srv := testRemoteState(t, testState(), 200)
|
|
|
|
defer srv.Close()
|
|
|
|
|
|
|
|
// Persist local remote state
|
|
|
|
s := terraform.NewState()
|
|
|
|
s.Serial = 5
|
|
|
|
s.Remote = conf
|
|
|
|
testStateFileRemote(t, s)
|
|
|
|
|
|
|
|
// Path where the archive will be "uploaded" to
|
|
|
|
archivePath := testTempFile(t)
|
|
|
|
defer os.Remove(archivePath)
|
|
|
|
|
|
|
|
client := &mockPushClient{File: archivePath}
|
|
|
|
ui := new(cli.MockUi)
|
|
|
|
c := &PushCommand{
|
|
|
|
Meta: Meta{
|
|
|
|
ContextOpts: testCtxConfig(testProvider()),
|
|
|
|
Ui: ui,
|
|
|
|
},
|
|
|
|
|
|
|
|
client: client,
|
|
|
|
}
|
|
|
|
|
|
|
|
args := []string{
|
2015-04-10 01:46:25 +02:00
|
|
|
"-vcs=false",
|
2015-03-05 23:55:15 +01:00
|
|
|
testFixturePath("push"),
|
|
|
|
}
|
|
|
|
if code := c.Run(args); code != 0 {
|
|
|
|
t.Fatalf("bad: %d\n\n%s", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
actual := testArchiveStr(t, archivePath)
|
2015-03-06 08:10:28 +01:00
|
|
|
expected := []string{
|
|
|
|
".terraform/",
|
|
|
|
".terraform/terraform.tfstate",
|
|
|
|
"main.tf",
|
|
|
|
}
|
2015-03-05 23:55:15 +01:00
|
|
|
if !reflect.DeepEqual(actual, expected) {
|
|
|
|
t.Fatalf("bad: %#v", actual)
|
|
|
|
}
|
2015-03-06 09:06:54 +01:00
|
|
|
|
2016-07-18 19:52:10 +02:00
|
|
|
variables := make(map[string]interface{})
|
2015-03-06 09:06:54 +01:00
|
|
|
if !reflect.DeepEqual(client.UpsertOptions.Variables, variables) {
|
|
|
|
t.Fatalf("bad: %#v", client.UpsertOptions)
|
|
|
|
}
|
2015-03-07 00:12:39 +01:00
|
|
|
|
|
|
|
if client.UpsertOptions.Name != "foo" {
|
|
|
|
t.Fatalf("bad: %#v", client.UpsertOptions)
|
|
|
|
}
|
2015-03-05 23:55:15 +01:00
|
|
|
}
|
|
|
|
|
2015-03-06 23:49:22 +01:00
|
|
|
func TestPush_input(t *testing.T) {
|
|
|
|
tmp, cwd := testCwd(t)
|
|
|
|
defer testFixCwd(t, tmp, cwd)
|
|
|
|
|
|
|
|
// Create remote state file, this should be pulled
|
|
|
|
conf, srv := testRemoteState(t, testState(), 200)
|
|
|
|
defer srv.Close()
|
|
|
|
|
|
|
|
// Persist local remote state
|
|
|
|
s := terraform.NewState()
|
|
|
|
s.Serial = 5
|
|
|
|
s.Remote = conf
|
|
|
|
testStateFileRemote(t, s)
|
|
|
|
|
|
|
|
// Path where the archive will be "uploaded" to
|
|
|
|
archivePath := testTempFile(t)
|
|
|
|
defer os.Remove(archivePath)
|
|
|
|
|
|
|
|
client := &mockPushClient{File: archivePath}
|
|
|
|
ui := new(cli.MockUi)
|
|
|
|
c := &PushCommand{
|
|
|
|
Meta: Meta{
|
|
|
|
ContextOpts: testCtxConfig(testProvider()),
|
|
|
|
Ui: ui,
|
|
|
|
},
|
|
|
|
|
|
|
|
client: client,
|
|
|
|
}
|
|
|
|
|
|
|
|
// Disable test mode so input would be asked and setup the
|
|
|
|
// input reader/writers.
|
|
|
|
test = false
|
|
|
|
defer func() { test = true }()
|
|
|
|
defaultInputReader = bytes.NewBufferString("foo\n")
|
|
|
|
defaultInputWriter = new(bytes.Buffer)
|
|
|
|
|
|
|
|
args := []string{
|
2015-04-10 01:46:25 +02:00
|
|
|
"-vcs=false",
|
2015-03-06 23:49:22 +01:00
|
|
|
testFixturePath("push-input"),
|
|
|
|
}
|
|
|
|
if code := c.Run(args); code != 0 {
|
|
|
|
t.Fatalf("bad: %d\n\n%s", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
|
2016-07-18 19:52:10 +02:00
|
|
|
variables := map[string]interface{}{
|
2015-03-06 23:49:22 +01:00
|
|
|
"foo": "foo",
|
|
|
|
}
|
|
|
|
if !reflect.DeepEqual(client.UpsertOptions.Variables, variables) {
|
2015-06-26 00:29:46 +02:00
|
|
|
t.Fatalf("bad: %#v", client.UpsertOptions.Variables)
|
2015-03-06 23:49:22 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-03-07 00:03:33 +01:00
|
|
|
func TestPush_inputPartial(t *testing.T) {
|
|
|
|
tmp, cwd := testCwd(t)
|
|
|
|
defer testFixCwd(t, tmp, cwd)
|
|
|
|
|
|
|
|
// Create remote state file, this should be pulled
|
|
|
|
conf, srv := testRemoteState(t, testState(), 200)
|
|
|
|
defer srv.Close()
|
|
|
|
|
|
|
|
// Persist local remote state
|
|
|
|
s := terraform.NewState()
|
|
|
|
s.Serial = 5
|
|
|
|
s.Remote = conf
|
|
|
|
testStateFileRemote(t, s)
|
|
|
|
|
|
|
|
// Path where the archive will be "uploaded" to
|
|
|
|
archivePath := testTempFile(t)
|
|
|
|
defer os.Remove(archivePath)
|
|
|
|
|
|
|
|
client := &mockPushClient{
|
|
|
|
File: archivePath,
|
2016-07-18 19:52:10 +02:00
|
|
|
GetResult: map[string]interface{}{"foo": "bar"},
|
2015-03-07 00:03:33 +01:00
|
|
|
}
|
|
|
|
ui := new(cli.MockUi)
|
|
|
|
c := &PushCommand{
|
|
|
|
Meta: Meta{
|
|
|
|
ContextOpts: testCtxConfig(testProvider()),
|
|
|
|
Ui: ui,
|
|
|
|
},
|
|
|
|
|
|
|
|
client: client,
|
|
|
|
}
|
|
|
|
|
|
|
|
// Disable test mode so input would be asked and setup the
|
|
|
|
// input reader/writers.
|
|
|
|
test = false
|
|
|
|
defer func() { test = true }()
|
|
|
|
defaultInputReader = bytes.NewBufferString("foo\n")
|
|
|
|
defaultInputWriter = new(bytes.Buffer)
|
|
|
|
|
|
|
|
args := []string{
|
2015-04-10 01:46:25 +02:00
|
|
|
"-vcs=false",
|
2015-03-07 00:03:33 +01:00
|
|
|
testFixturePath("push-input-partial"),
|
|
|
|
}
|
|
|
|
if code := c.Run(args); code != 0 {
|
|
|
|
t.Fatalf("bad: %d\n\n%s", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
|
2016-07-18 19:52:10 +02:00
|
|
|
variables := map[string]interface{}{
|
2015-03-07 00:03:33 +01:00
|
|
|
"foo": "bar",
|
|
|
|
"bar": "foo",
|
|
|
|
}
|
|
|
|
if !reflect.DeepEqual(client.UpsertOptions.Variables, variables) {
|
|
|
|
t.Fatalf("bad: %#v", client.UpsertOptions)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-06-29 21:24:13 +02:00
|
|
|
// This tests that the push command will override Atlas variables
|
|
|
|
// if requested.
|
|
|
|
func TestPush_localOverride(t *testing.T) {
|
2015-04-08 00:34:06 +02:00
|
|
|
// Disable test mode so input would be asked and setup the
|
|
|
|
// input reader/writers.
|
|
|
|
test = false
|
|
|
|
defer func() { test = true }()
|
|
|
|
defaultInputReader = bytes.NewBufferString("nope\n")
|
|
|
|
defaultInputWriter = new(bytes.Buffer)
|
|
|
|
|
|
|
|
tmp, cwd := testCwd(t)
|
|
|
|
defer testFixCwd(t, tmp, cwd)
|
|
|
|
|
|
|
|
// Create remote state file, this should be pulled
|
|
|
|
conf, srv := testRemoteState(t, testState(), 200)
|
|
|
|
defer srv.Close()
|
|
|
|
|
|
|
|
// Persist local remote state
|
|
|
|
s := terraform.NewState()
|
|
|
|
s.Serial = 5
|
|
|
|
s.Remote = conf
|
|
|
|
testStateFileRemote(t, s)
|
|
|
|
|
|
|
|
// Path where the archive will be "uploaded" to
|
|
|
|
archivePath := testTempFile(t)
|
|
|
|
defer os.Remove(archivePath)
|
|
|
|
|
|
|
|
client := &mockPushClient{File: archivePath}
|
2015-05-09 01:54:38 +02:00
|
|
|
// Provided vars should override existing ones
|
2016-07-18 19:52:10 +02:00
|
|
|
client.GetResult = map[string]interface{}{
|
2015-05-09 01:54:38 +02:00
|
|
|
"foo": "old",
|
|
|
|
}
|
2015-04-08 00:34:06 +02:00
|
|
|
ui := new(cli.MockUi)
|
|
|
|
c := &PushCommand{
|
|
|
|
Meta: Meta{
|
|
|
|
ContextOpts: testCtxConfig(testProvider()),
|
|
|
|
Ui: ui,
|
|
|
|
},
|
|
|
|
|
|
|
|
client: client,
|
|
|
|
}
|
|
|
|
|
2015-06-29 21:24:13 +02:00
|
|
|
path := testFixturePath("push-tfvars")
|
|
|
|
args := []string{
|
|
|
|
"-var-file", path + "/terraform.tfvars",
|
|
|
|
"-vcs=false",
|
2015-06-29 22:53:05 +02:00
|
|
|
"-overwrite=foo",
|
2015-06-29 21:24:13 +02:00
|
|
|
path,
|
|
|
|
}
|
|
|
|
if code := c.Run(args); code != 0 {
|
|
|
|
t.Fatalf("bad: %d\n\n%s", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
actual := testArchiveStr(t, archivePath)
|
|
|
|
expected := []string{
|
|
|
|
".terraform/",
|
|
|
|
".terraform/terraform.tfstate",
|
|
|
|
"main.tf",
|
|
|
|
"terraform.tfvars",
|
|
|
|
}
|
|
|
|
if !reflect.DeepEqual(actual, expected) {
|
|
|
|
t.Fatalf("bad: %#v", actual)
|
|
|
|
}
|
|
|
|
|
|
|
|
if client.UpsertOptions.Name != "foo" {
|
|
|
|
t.Fatalf("bad: %#v", client.UpsertOptions)
|
|
|
|
}
|
|
|
|
|
2016-07-25 21:56:56 +02:00
|
|
|
variables := pushTFVars()
|
|
|
|
|
2015-06-29 21:24:13 +02:00
|
|
|
if !reflect.DeepEqual(client.UpsertOptions.Variables, variables) {
|
|
|
|
t.Fatalf("bad: %#v", client.UpsertOptions)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// This tests that the push command prefers Atlas variables over
|
|
|
|
// local ones.
|
|
|
|
func TestPush_preferAtlas(t *testing.T) {
|
|
|
|
// Disable test mode so input would be asked and setup the
|
|
|
|
// input reader/writers.
|
|
|
|
test = false
|
|
|
|
defer func() { test = true }()
|
|
|
|
defaultInputReader = bytes.NewBufferString("nope\n")
|
|
|
|
defaultInputWriter = new(bytes.Buffer)
|
|
|
|
|
|
|
|
tmp, cwd := testCwd(t)
|
|
|
|
defer testFixCwd(t, tmp, cwd)
|
|
|
|
|
|
|
|
// Create remote state file, this should be pulled
|
|
|
|
conf, srv := testRemoteState(t, testState(), 200)
|
|
|
|
defer srv.Close()
|
|
|
|
|
|
|
|
// Persist local remote state
|
|
|
|
s := terraform.NewState()
|
|
|
|
s.Serial = 5
|
|
|
|
s.Remote = conf
|
|
|
|
testStateFileRemote(t, s)
|
|
|
|
|
|
|
|
// Path where the archive will be "uploaded" to
|
|
|
|
archivePath := testTempFile(t)
|
|
|
|
defer os.Remove(archivePath)
|
|
|
|
|
|
|
|
client := &mockPushClient{File: archivePath}
|
|
|
|
// Provided vars should override existing ones
|
2016-07-18 19:52:10 +02:00
|
|
|
client.GetResult = map[string]interface{}{
|
2015-06-29 21:24:13 +02:00
|
|
|
"foo": "old",
|
|
|
|
}
|
|
|
|
ui := new(cli.MockUi)
|
|
|
|
c := &PushCommand{
|
|
|
|
Meta: Meta{
|
|
|
|
ContextOpts: testCtxConfig(testProvider()),
|
|
|
|
Ui: ui,
|
|
|
|
},
|
|
|
|
|
|
|
|
client: client,
|
|
|
|
}
|
|
|
|
|
|
|
|
path := testFixturePath("push-tfvars")
|
|
|
|
args := []string{
|
|
|
|
"-var-file", path + "/terraform.tfvars",
|
|
|
|
"-vcs=false",
|
|
|
|
path,
|
|
|
|
}
|
|
|
|
if code := c.Run(args); code != 0 {
|
|
|
|
t.Fatalf("bad: %d\n\n%s", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
actual := testArchiveStr(t, archivePath)
|
|
|
|
expected := []string{
|
|
|
|
".terraform/",
|
|
|
|
".terraform/terraform.tfstate",
|
|
|
|
"main.tf",
|
|
|
|
"terraform.tfvars",
|
|
|
|
}
|
|
|
|
if !reflect.DeepEqual(actual, expected) {
|
|
|
|
t.Fatalf("bad: %#v", actual)
|
|
|
|
}
|
|
|
|
|
|
|
|
if client.UpsertOptions.Name != "foo" {
|
|
|
|
t.Fatalf("bad: %#v", client.UpsertOptions)
|
|
|
|
}
|
|
|
|
|
2016-07-25 21:56:56 +02:00
|
|
|
variables := pushTFVars()
|
|
|
|
variables["foo"] = "old"
|
|
|
|
|
2015-06-29 21:24:13 +02:00
|
|
|
if !reflect.DeepEqual(client.UpsertOptions.Variables, variables) {
|
2016-07-25 21:56:56 +02:00
|
|
|
t.Fatalf("bad: %#v", client.UpsertOptions.Variables)
|
2015-06-29 21:24:13 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// This tests that the push command will send the variables in tfvars
|
|
|
|
func TestPush_tfvars(t *testing.T) {
|
|
|
|
// Disable test mode so input would be asked and setup the
|
|
|
|
// input reader/writers.
|
|
|
|
test = false
|
|
|
|
defer func() { test = true }()
|
|
|
|
defaultInputReader = bytes.NewBufferString("nope\n")
|
|
|
|
defaultInputWriter = new(bytes.Buffer)
|
|
|
|
|
|
|
|
tmp, cwd := testCwd(t)
|
|
|
|
defer testFixCwd(t, tmp, cwd)
|
|
|
|
|
|
|
|
// Create remote state file, this should be pulled
|
|
|
|
conf, srv := testRemoteState(t, testState(), 200)
|
|
|
|
defer srv.Close()
|
|
|
|
|
|
|
|
// Persist local remote state
|
|
|
|
s := terraform.NewState()
|
|
|
|
s.Serial = 5
|
|
|
|
s.Remote = conf
|
|
|
|
testStateFileRemote(t, s)
|
|
|
|
|
|
|
|
// Path where the archive will be "uploaded" to
|
|
|
|
archivePath := testTempFile(t)
|
|
|
|
defer os.Remove(archivePath)
|
|
|
|
|
|
|
|
client := &mockPushClient{File: archivePath}
|
|
|
|
ui := new(cli.MockUi)
|
|
|
|
c := &PushCommand{
|
|
|
|
Meta: Meta{
|
|
|
|
ContextOpts: testCtxConfig(testProvider()),
|
|
|
|
Ui: ui,
|
|
|
|
},
|
|
|
|
|
|
|
|
client: client,
|
|
|
|
}
|
|
|
|
|
2015-04-08 00:34:06 +02:00
|
|
|
path := testFixturePath("push-tfvars")
|
|
|
|
args := []string{
|
|
|
|
"-var-file", path + "/terraform.tfvars",
|
2015-04-10 01:46:25 +02:00
|
|
|
"-vcs=false",
|
2015-04-08 00:34:06 +02:00
|
|
|
path,
|
|
|
|
}
|
|
|
|
if code := c.Run(args); code != 0 {
|
|
|
|
t.Fatalf("bad: %d\n\n%s", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
actual := testArchiveStr(t, archivePath)
|
|
|
|
expected := []string{
|
|
|
|
".terraform/",
|
|
|
|
".terraform/terraform.tfstate",
|
|
|
|
"main.tf",
|
|
|
|
"terraform.tfvars",
|
|
|
|
}
|
|
|
|
if !reflect.DeepEqual(actual, expected) {
|
|
|
|
t.Fatalf("bad: %#v", actual)
|
|
|
|
}
|
|
|
|
|
|
|
|
if client.UpsertOptions.Name != "foo" {
|
|
|
|
t.Fatalf("bad: %#v", client.UpsertOptions)
|
|
|
|
}
|
|
|
|
|
2016-07-25 21:56:56 +02:00
|
|
|
variables := pushTFVars()
|
|
|
|
|
|
|
|
// make sure these dind't go missing for some reason
|
|
|
|
for k, v := range variables {
|
|
|
|
if !reflect.DeepEqual(client.UpsertOptions.Variables[k], v) {
|
2016-07-27 02:37:41 +02:00
|
|
|
t.Fatalf("bad: %#v", client.UpsertOptions.Variables[k])
|
2016-07-25 21:56:56 +02:00
|
|
|
}
|
2015-04-08 00:34:06 +02:00
|
|
|
}
|
2016-07-25 21:56:56 +02:00
|
|
|
|
2016-07-27 02:37:41 +02:00
|
|
|
//now check TFVars
|
2016-07-25 21:56:56 +02:00
|
|
|
tfvars := []atlas.TFVar{
|
|
|
|
{"bar", "foo", false},
|
2016-07-27 02:37:41 +02:00
|
|
|
{"baz", `{
|
|
|
|
A = "a"
|
|
|
|
B = "b"
|
|
|
|
interp = "${file("t.txt")}"
|
|
|
|
}
|
|
|
|
`, true},
|
|
|
|
{"fob", `["a", "b", "c", "quotes \"in\" quotes"]` + "\n", true},
|
2016-07-25 21:56:56 +02:00
|
|
|
{"foo", "bar", false},
|
|
|
|
}
|
|
|
|
|
2016-07-27 02:37:41 +02:00
|
|
|
for i, expected := range tfvars {
|
|
|
|
got := client.UpsertOptions.TFVars[i]
|
|
|
|
if got != expected {
|
|
|
|
t.Logf("%2d expected: %#v", i, expected)
|
|
|
|
t.Logf(" got: %#v", got)
|
|
|
|
}
|
2015-04-08 00:34:06 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-03-07 00:14:41 +01:00
|
|
|
func TestPush_name(t *testing.T) {
|
|
|
|
tmp, cwd := testCwd(t)
|
|
|
|
defer testFixCwd(t, tmp, cwd)
|
|
|
|
|
|
|
|
// Create remote state file, this should be pulled
|
|
|
|
conf, srv := testRemoteState(t, testState(), 200)
|
|
|
|
defer srv.Close()
|
|
|
|
|
|
|
|
// Persist local remote state
|
|
|
|
s := terraform.NewState()
|
|
|
|
s.Serial = 5
|
|
|
|
s.Remote = conf
|
|
|
|
testStateFileRemote(t, s)
|
|
|
|
|
|
|
|
// Path where the archive will be "uploaded" to
|
|
|
|
archivePath := testTempFile(t)
|
|
|
|
defer os.Remove(archivePath)
|
|
|
|
|
|
|
|
client := &mockPushClient{File: archivePath}
|
|
|
|
ui := new(cli.MockUi)
|
|
|
|
c := &PushCommand{
|
|
|
|
Meta: Meta{
|
|
|
|
ContextOpts: testCtxConfig(testProvider()),
|
|
|
|
Ui: ui,
|
|
|
|
},
|
|
|
|
|
|
|
|
client: client,
|
|
|
|
}
|
|
|
|
|
|
|
|
args := []string{
|
|
|
|
"-name", "bar",
|
2015-04-10 01:46:25 +02:00
|
|
|
"-vcs=false",
|
2015-03-07 00:14:41 +01:00
|
|
|
testFixturePath("push"),
|
|
|
|
}
|
|
|
|
if code := c.Run(args); code != 0 {
|
|
|
|
t.Fatalf("bad: %d\n\n%s", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
if client.UpsertOptions.Name != "bar" {
|
|
|
|
t.Fatalf("bad: %#v", client.UpsertOptions)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-03-05 05:42:26 +01:00
|
|
|
func TestPush_noState(t *testing.T) {
|
|
|
|
tmp, cwd := testCwd(t)
|
|
|
|
defer testFixCwd(t, tmp, cwd)
|
|
|
|
|
|
|
|
ui := new(cli.MockUi)
|
|
|
|
c := &PushCommand{
|
|
|
|
Meta: Meta{
|
|
|
|
ContextOpts: testCtxConfig(testProvider()),
|
|
|
|
Ui: ui,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
args := []string{}
|
|
|
|
if code := c.Run(args); code != 1 {
|
|
|
|
t.Fatalf("bad: \n%s", ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPush_noRemoteState(t *testing.T) {
|
|
|
|
state := &terraform.State{
|
|
|
|
Modules: []*terraform.ModuleState{
|
|
|
|
&terraform.ModuleState{
|
|
|
|
Path: []string{"root"},
|
|
|
|
Resources: map[string]*terraform.ResourceState{
|
|
|
|
"test_instance.foo": &terraform.ResourceState{
|
|
|
|
Type: "test_instance",
|
|
|
|
Primary: &terraform.InstanceState{
|
|
|
|
ID: "bar",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
statePath := testStateFile(t, state)
|
|
|
|
|
|
|
|
ui := new(cli.MockUi)
|
|
|
|
c := &PushCommand{
|
|
|
|
Meta: Meta{
|
|
|
|
Ui: ui,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
args := []string{
|
|
|
|
"-state", statePath,
|
|
|
|
}
|
|
|
|
if code := c.Run(args); code != 1 {
|
|
|
|
t.Fatalf("bad: %d\n\n%s", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
}
|
2015-03-05 23:55:15 +01:00
|
|
|
|
|
|
|
func TestPush_plan(t *testing.T) {
|
|
|
|
tmp, cwd := testCwd(t)
|
|
|
|
defer testFixCwd(t, tmp, cwd)
|
|
|
|
|
|
|
|
// Create remote state file, this should be pulled
|
|
|
|
conf, srv := testRemoteState(t, testState(), 200)
|
|
|
|
defer srv.Close()
|
|
|
|
|
|
|
|
// Persist local remote state
|
|
|
|
s := terraform.NewState()
|
|
|
|
s.Serial = 5
|
|
|
|
s.Remote = conf
|
|
|
|
testStateFileRemote(t, s)
|
|
|
|
|
|
|
|
// Create a plan
|
|
|
|
planPath := testPlanFile(t, &terraform.Plan{
|
|
|
|
Module: testModule(t, "apply"),
|
|
|
|
})
|
|
|
|
|
|
|
|
ui := new(cli.MockUi)
|
|
|
|
c := &PushCommand{
|
|
|
|
Meta: Meta{
|
|
|
|
ContextOpts: testCtxConfig(testProvider()),
|
|
|
|
Ui: ui,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
args := []string{planPath}
|
|
|
|
if code := c.Run(args); code != 1 {
|
|
|
|
t.Fatalf("bad: %d\n\n%s", code, ui.ErrorWriter.String())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func testArchiveStr(t *testing.T, path string) []string {
|
|
|
|
f, err := os.Open(path)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
defer f.Close()
|
|
|
|
|
|
|
|
// Ungzip
|
|
|
|
gzipR, err := gzip.NewReader(f)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Accumulator
|
|
|
|
result := make([]string, 0, 10)
|
|
|
|
|
|
|
|
// Untar
|
|
|
|
tarR := tar.NewReader(gzipR)
|
|
|
|
for {
|
|
|
|
header, err := tarR.Next()
|
|
|
|
if err == io.EOF {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
result = append(result, header.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
sort.Strings(result)
|
|
|
|
return result
|
|
|
|
}
|
2016-07-25 21:56:56 +02:00
|
|
|
|
|
|
|
// the structure returned from the push-tfvars test fixture
|
|
|
|
func pushTFVars() map[string]interface{} {
|
|
|
|
return map[string]interface{}{
|
|
|
|
"foo": "bar",
|
|
|
|
"bar": "foo",
|
|
|
|
"baz": map[string]interface{}{
|
2016-07-27 02:37:41 +02:00
|
|
|
"A": "a",
|
|
|
|
"B": "b",
|
|
|
|
"interp": `${file("t.txt")}`,
|
2016-07-25 21:56:56 +02:00
|
|
|
},
|
2016-07-27 02:37:41 +02:00
|
|
|
"fob": []interface{}{"a", "b", "c", `quotes "in" quotes`},
|
2016-07-25 21:56:56 +02:00
|
|
|
}
|
|
|
|
}
|