2014-06-18 03:40:32 +02:00
|
|
|
package diff
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2014-06-20 21:12:24 +02:00
|
|
|
"github.com/hashicorp/terraform/config"
|
2014-06-18 03:40:32 +02:00
|
|
|
"github.com/hashicorp/terraform/terraform"
|
|
|
|
)
|
|
|
|
|
2014-07-02 01:06:06 +02:00
|
|
|
func TestResourceBuilder_complex(t *testing.T) {
|
|
|
|
rb := &ResourceBuilder{
|
|
|
|
Attrs: map[string]AttrType{
|
|
|
|
"listener": AttrTypeUpdate,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
state := &terraform.ResourceState{
|
|
|
|
ID: "foo",
|
|
|
|
Attributes: map[string]string{
|
|
|
|
"ignore": "1",
|
|
|
|
"listener.#": "1",
|
|
|
|
"listener.0.port": "80",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
c := testConfig(t, map[string]interface{}{
|
|
|
|
"listener": []interface{}{
|
|
|
|
map[interface{}]interface{}{
|
|
|
|
"port": 3000,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}, nil)
|
|
|
|
|
|
|
|
diff, err := rb.Diff(state, c)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
if diff == nil {
|
|
|
|
t.Fatal("should not be nil")
|
|
|
|
}
|
|
|
|
|
|
|
|
actual := testResourceDiffStr(diff)
|
|
|
|
expected := testRBComplexDiff
|
|
|
|
if actual != expected {
|
|
|
|
t.Fatalf("bad: %s", actual)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-06-18 03:40:32 +02:00
|
|
|
func TestResourceBuilder_new(t *testing.T) {
|
|
|
|
rb := &ResourceBuilder{
|
2014-07-02 01:06:06 +02:00
|
|
|
Attrs: map[string]AttrType{
|
|
|
|
"foo": AttrTypeUpdate,
|
|
|
|
},
|
|
|
|
ComputedAttrs: []string{"private_ip"},
|
2014-06-18 03:40:32 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
state := &terraform.ResourceState{}
|
|
|
|
|
|
|
|
c := testConfig(t, map[string]interface{}{
|
|
|
|
"foo": "bar",
|
|
|
|
}, nil)
|
|
|
|
|
|
|
|
diff, err := rb.Diff(state, c)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
if diff == nil {
|
|
|
|
t.Fatal("should not be nil")
|
|
|
|
}
|
|
|
|
|
|
|
|
actual := testResourceDiffStr(diff)
|
|
|
|
expected := testRBNewDiff
|
|
|
|
if actual != expected {
|
|
|
|
t.Fatalf("bad: %s", actual)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestResourceBuilder_requiresNew(t *testing.T) {
|
|
|
|
rb := &ResourceBuilder{
|
2014-07-02 01:06:06 +02:00
|
|
|
ComputedAttrs: []string{"private_ip"},
|
|
|
|
Attrs: map[string]AttrType{
|
|
|
|
"ami": AttrTypeCreate,
|
|
|
|
},
|
2014-06-18 03:40:32 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
state := &terraform.ResourceState{
|
|
|
|
ID: "1",
|
|
|
|
Attributes: map[string]string{
|
|
|
|
"ami": "foo",
|
|
|
|
"private_ip": "127.0.0.1",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
c := testConfig(t, map[string]interface{}{
|
|
|
|
"ami": "bar",
|
|
|
|
}, nil)
|
|
|
|
|
|
|
|
diff, err := rb.Diff(state, c)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
if diff == nil {
|
|
|
|
t.Fatal("should not be nil")
|
|
|
|
}
|
|
|
|
|
|
|
|
actual := testResourceDiffStr(diff)
|
|
|
|
expected := testRBRequiresNewDiff
|
|
|
|
if actual != expected {
|
|
|
|
t.Fatalf("bad: %s", actual)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestResourceBuilder_same(t *testing.T) {
|
|
|
|
rb := &ResourceBuilder{
|
2014-07-02 01:06:06 +02:00
|
|
|
ComputedAttrs: []string{"private_ip"},
|
2014-06-18 03:40:32 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
state := &terraform.ResourceState{
|
|
|
|
ID: "1",
|
|
|
|
Attributes: map[string]string{
|
|
|
|
"foo": "bar",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
c := testConfig(t, map[string]interface{}{
|
|
|
|
"foo": "bar",
|
|
|
|
}, nil)
|
|
|
|
|
|
|
|
diff, err := rb.Diff(state, c)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
if diff != nil {
|
|
|
|
t.Fatal("should not diff: %s", diff)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-06-20 21:12:24 +02:00
|
|
|
func TestResourceBuilder_unknown(t *testing.T) {
|
2014-07-02 01:06:06 +02:00
|
|
|
rb := &ResourceBuilder{
|
|
|
|
Attrs: map[string]AttrType{
|
|
|
|
"foo": AttrTypeUpdate,
|
|
|
|
},
|
|
|
|
}
|
2014-06-20 21:12:24 +02:00
|
|
|
|
|
|
|
state := &terraform.ResourceState{}
|
|
|
|
|
|
|
|
c := testConfig(t, map[string]interface{}{
|
|
|
|
"foo": "${var.unknown}",
|
|
|
|
}, map[string]string{
|
|
|
|
"var.foo": "bar",
|
|
|
|
"var.unknown": config.UnknownVariableValue,
|
|
|
|
})
|
|
|
|
|
|
|
|
diff, err := rb.Diff(state, c)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
if diff == nil {
|
|
|
|
t.Fatal("should not be nil")
|
|
|
|
}
|
|
|
|
|
|
|
|
actual := testResourceDiffStr(diff)
|
|
|
|
expected := testRBUnknownDiff
|
|
|
|
if actual != expected {
|
|
|
|
t.Fatalf("bad: %s", actual)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestResourceBuilder_vars(t *testing.T) {
|
2014-07-02 01:06:06 +02:00
|
|
|
rb := &ResourceBuilder{
|
|
|
|
Attrs: map[string]AttrType{
|
|
|
|
"foo": AttrTypeUpdate,
|
|
|
|
},
|
|
|
|
}
|
2014-06-20 21:12:24 +02:00
|
|
|
|
|
|
|
state := &terraform.ResourceState{}
|
|
|
|
|
|
|
|
c := testConfig(t, map[string]interface{}{
|
|
|
|
"foo": "${var.foo}",
|
|
|
|
}, map[string]string{
|
|
|
|
"var.foo": "bar",
|
|
|
|
})
|
|
|
|
|
|
|
|
diff, err := rb.Diff(state, c)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
if diff == nil {
|
|
|
|
t.Fatal("should not be nil")
|
|
|
|
}
|
|
|
|
|
|
|
|
actual := testResourceDiffStr(diff)
|
|
|
|
expected := testRBVarsDiff
|
|
|
|
if actual != expected {
|
|
|
|
t.Fatalf("bad: %s", actual)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-07-02 01:06:06 +02:00
|
|
|
const testRBComplexDiff = `UPDATE
|
|
|
|
IN listener.0.port: "80" => "3000"
|
|
|
|
`
|
|
|
|
|
2014-06-23 22:14:08 +02:00
|
|
|
const testRBNewDiff = `UPDATE
|
2014-06-23 21:49:30 +02:00
|
|
|
IN foo: "" => "bar"
|
2014-07-07 23:57:41 +02:00
|
|
|
OUT id: "" => "<computed>"
|
2014-06-23 21:49:30 +02:00
|
|
|
OUT private_ip: "" => "<computed>"
|
2014-06-18 03:40:32 +02:00
|
|
|
`
|
|
|
|
|
|
|
|
const testRBRequiresNewDiff = `CREATE
|
2014-06-23 21:49:30 +02:00
|
|
|
IN ami: "foo" => "bar" (forces new resource)
|
2014-07-07 23:57:41 +02:00
|
|
|
OUT id: "1" => "<computed>"
|
2014-06-23 21:49:30 +02:00
|
|
|
OUT private_ip: "127.0.0.1" => "<computed>"
|
2014-06-18 03:40:32 +02:00
|
|
|
`
|
2014-06-20 21:12:24 +02:00
|
|
|
|
2014-06-23 22:14:08 +02:00
|
|
|
const testRBUnknownDiff = `UPDATE
|
2014-06-23 21:49:30 +02:00
|
|
|
IN foo: "" => "${var.unknown}"
|
2014-07-07 23:57:41 +02:00
|
|
|
OUT id: "" => "<computed>"
|
2014-06-20 21:12:24 +02:00
|
|
|
`
|
|
|
|
|
2014-06-23 22:14:08 +02:00
|
|
|
const testRBVarsDiff = `UPDATE
|
2014-06-23 21:49:30 +02:00
|
|
|
IN foo: "" => "bar"
|
2014-07-07 23:57:41 +02:00
|
|
|
OUT id: "" => "<computed>"
|
2014-06-20 21:12:24 +02:00
|
|
|
`
|