mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-02 12:17:39 -06:00
200 lines
3.7 KiB
Go
200 lines
3.7 KiB
Go
package config
|
|
|
|
import (
|
|
"path/filepath"
|
|
"reflect"
|
|
"strings"
|
|
"testing"
|
|
)
|
|
|
|
// This is the directory where our test fixtures are.
|
|
const fixtureDir = "./test-fixtures"
|
|
|
|
func TestConfigGraph(t *testing.T) {
|
|
c, err := Load(filepath.Join(fixtureDir, "resource_graph.tf"))
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
graph := c.Graph()
|
|
if err := graph.Validate(); err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
actual := strings.TrimSpace(graph.String())
|
|
expected := resourceGraphValue
|
|
|
|
if actual != strings.TrimSpace(expected) {
|
|
t.Fatalf("bad:\n%s", actual)
|
|
}
|
|
}
|
|
|
|
func TestConfigGraph_cycle(t *testing.T) {
|
|
c, err := Load(filepath.Join(fixtureDir, "resource_graph_cycle.tf"))
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
graph := c.Graph()
|
|
if err := graph.Validate(); err == nil {
|
|
t.Fatal("graph should be invalid")
|
|
}
|
|
}
|
|
|
|
func TestNewResourceVariable(t *testing.T) {
|
|
v, err := NewResourceVariable("foo.bar.baz")
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
if v.Type != "foo" {
|
|
t.Fatalf("bad: %#v", v)
|
|
}
|
|
if v.Name != "bar" {
|
|
t.Fatalf("bad: %#v", v)
|
|
}
|
|
if v.Field != "baz" {
|
|
t.Fatalf("bad: %#v", v)
|
|
}
|
|
|
|
if v.FullKey() != "foo.bar.baz" {
|
|
t.Fatalf("bad: %#v", v)
|
|
}
|
|
}
|
|
|
|
func TestNewUserVariable(t *testing.T) {
|
|
v, err := NewUserVariable("var.bar")
|
|
if err != nil {
|
|
t.Fatalf("err: %s", err)
|
|
}
|
|
|
|
if v.Name != "bar" {
|
|
t.Fatalf("bad: %#v", v.Name)
|
|
}
|
|
if v.FullKey() != "var.bar" {
|
|
t.Fatalf("bad: %#v", v)
|
|
}
|
|
}
|
|
|
|
func TestProviderConfigReplaceVariables(t *testing.T) {
|
|
r := &ProviderConfig{
|
|
Config: map[string]interface{}{
|
|
"foo": "${var.bar}",
|
|
},
|
|
}
|
|
|
|
values := map[string]string{
|
|
"var.bar": "value",
|
|
}
|
|
|
|
r2 := r.ReplaceVariables(values)
|
|
|
|
expected := &ProviderConfig{
|
|
Config: map[string]interface{}{
|
|
"foo": "value",
|
|
},
|
|
}
|
|
if !reflect.DeepEqual(r2, expected) {
|
|
t.Fatalf("bad: %#v", r2)
|
|
}
|
|
|
|
/*
|
|
TODO(mitchellh): Eventually, preserve original config...
|
|
|
|
expectedOriginal := &Resource{
|
|
Name: "foo",
|
|
Type: "bar",
|
|
Config: map[string]interface{}{
|
|
"foo": "${var.bar}",
|
|
},
|
|
}
|
|
|
|
if !reflect.DeepEqual(r, expectedOriginal) {
|
|
t.Fatalf("bad: %#v", r)
|
|
}
|
|
*/
|
|
}
|
|
|
|
func TestResourceProviderConfigName(t *testing.T) {
|
|
r := &Resource{
|
|
Name: "foo",
|
|
Type: "aws_instance",
|
|
}
|
|
|
|
pcs := map[string]*ProviderConfig{
|
|
"aw": new(ProviderConfig),
|
|
"aws": new(ProviderConfig),
|
|
"a": new(ProviderConfig),
|
|
"gce_": new(ProviderConfig),
|
|
}
|
|
|
|
n := r.ProviderConfigName(pcs)
|
|
if n != "aws" {
|
|
t.Fatalf("bad: %s", n)
|
|
}
|
|
}
|
|
|
|
func TestResourceReplaceVariables(t *testing.T) {
|
|
r := &Resource{
|
|
Name: "foo",
|
|
Type: "bar",
|
|
Config: map[string]interface{}{
|
|
"foo": "${var.bar}",
|
|
},
|
|
}
|
|
|
|
values := map[string]string{
|
|
"var.bar": "value",
|
|
}
|
|
|
|
r2 := r.ReplaceVariables(values)
|
|
|
|
expected := &Resource{
|
|
Name: "foo",
|
|
Type: "bar",
|
|
Config: map[string]interface{}{
|
|
"foo": "value",
|
|
},
|
|
}
|
|
if !reflect.DeepEqual(r2, expected) {
|
|
t.Fatalf("bad: %#v", r2)
|
|
}
|
|
|
|
/*
|
|
TODO(mitchellh): Eventually, preserve original config...
|
|
|
|
expectedOriginal := &Resource{
|
|
Name: "foo",
|
|
Type: "bar",
|
|
Config: map[string]interface{}{
|
|
"foo": "${var.bar}",
|
|
},
|
|
}
|
|
|
|
if !reflect.DeepEqual(r, expectedOriginal) {
|
|
t.Fatalf("bad: %#v", r)
|
|
}
|
|
*/
|
|
}
|
|
|
|
const resourceGraphValue = `
|
|
root: root
|
|
openstack_floating_ip.random
|
|
aws_security_group.firewall
|
|
aws_security_group.firewall -> provider.aws
|
|
aws_instance.web
|
|
aws_instance.web -> aws_security_group.firewall
|
|
aws_instance.web -> provider.aws
|
|
aws_load_balancer.weblb
|
|
aws_load_balancer.weblb -> aws_instance.web
|
|
aws_load_balancer.weblb -> provider.aws
|
|
provider.aws
|
|
provider.aws -> openstack_floating_ip.random
|
|
root
|
|
root -> openstack_floating_ip.random
|
|
root -> aws_security_group.firewall
|
|
root -> aws_instance.web
|
|
root -> aws_load_balancer.weblb
|
|
root -> provider.aws
|
|
`
|