terraform: add input mode to only ask for unset variables
This adds a new input mode for Context.Input() that will only ask for variable values that are not set.
This commit is contained in:
parent
55d682482a
commit
2dce764d75
|
@ -16,9 +16,12 @@ import (
|
||||||
type InputMode byte
|
type InputMode byte
|
||||||
|
|
||||||
const (
|
const (
|
||||||
// InputModeVar asks for variables
|
// InputModeVar asks for all variables
|
||||||
InputModeVar InputMode = 1 << iota
|
InputModeVar InputMode = 1 << iota
|
||||||
|
|
||||||
|
// InputModeVarUnset asks for variables which are not set yet
|
||||||
|
InputModeVarUnset
|
||||||
|
|
||||||
// InputModeProvider asks for provider variables
|
// InputModeProvider asks for provider variables
|
||||||
InputModeProvider
|
InputModeProvider
|
||||||
|
|
||||||
|
@ -154,6 +157,14 @@ func (c *Context) Input(mode InputMode) error {
|
||||||
}
|
}
|
||||||
sort.Strings(names)
|
sort.Strings(names)
|
||||||
for _, n := range names {
|
for _, n := range names {
|
||||||
|
// If we only care about unset variables, then if the variabel
|
||||||
|
// is set, continue on.
|
||||||
|
if mode&InputModeVarUnset != 0 {
|
||||||
|
if _, ok := c.variables[n]; ok {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
v := m[n]
|
v := m[n]
|
||||||
switch v.Type() {
|
switch v.Type() {
|
||||||
case config.VariableTypeMap:
|
case config.VariableTypeMap:
|
||||||
|
@ -365,6 +376,21 @@ func (c *Context) Validate() ([]string, []error) {
|
||||||
return walker.ValidationWarnings, rerrs.Errors
|
return walker.ValidationWarnings, rerrs.Errors
|
||||||
}
|
}
|
||||||
|
|
||||||
|
<<<<<<< Updated upstream
|
||||||
|
=======
|
||||||
|
// Variables will return the mapping of variables that were defined
|
||||||
|
// for this Context. If Input was called, this mapping may be different
|
||||||
|
// than what was given.
|
||||||
|
func (c *Context) Variables() map[string]string {
|
||||||
|
return c.variables
|
||||||
|
}
|
||||||
|
|
||||||
|
// SetVariable sets a variable after a context has already been built.
|
||||||
|
func (c *Context) SetVariable(k, v string) {
|
||||||
|
c.variables[k] = v
|
||||||
|
}
|
||||||
|
|
||||||
|
>>>>>>> Stashed changes
|
||||||
func (c *Context) acquireRun() chan<- struct{} {
|
func (c *Context) acquireRun() chan<- struct{} {
|
||||||
c.l.Lock()
|
c.l.Lock()
|
||||||
defer c.l.Unlock()
|
defer c.l.Unlock()
|
||||||
|
|
|
@ -2758,6 +2758,48 @@ func TestContext2Input_varOnly(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestContext2Input_varOnlyUnset(t *testing.T) {
|
||||||
|
input := new(MockUIInput)
|
||||||
|
m := testModule(t, "input-vars-unset")
|
||||||
|
p := testProvider("aws")
|
||||||
|
p.ApplyFn = testApplyFn
|
||||||
|
p.DiffFn = testDiffFn
|
||||||
|
ctx := testContext2(t, &ContextOpts{
|
||||||
|
Module: m,
|
||||||
|
Providers: map[string]ResourceProviderFactory{
|
||||||
|
"aws": testProviderFuncFixed(p),
|
||||||
|
},
|
||||||
|
Variables: map[string]string{
|
||||||
|
"foo": "foovalue",
|
||||||
|
},
|
||||||
|
UIInput: input,
|
||||||
|
})
|
||||||
|
|
||||||
|
input.InputReturnMap = map[string]string{
|
||||||
|
"var.foo": "nope",
|
||||||
|
"var.bar": "baz",
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := ctx.Input(InputModeVar | InputModeVarUnset); err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if _, err := ctx.Plan(nil); err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
state, err := ctx.Apply()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
actualStr := strings.TrimSpace(state.String())
|
||||||
|
expectedStr := strings.TrimSpace(testTerraformInputVarOnlyUnsetStr)
|
||||||
|
if actualStr != expectedStr {
|
||||||
|
t.Fatalf("bad: \n%s", actualStr)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func TestContext2Apply(t *testing.T) {
|
func TestContext2Apply(t *testing.T) {
|
||||||
m := testModule(t, "apply-good")
|
m := testModule(t, "apply-good")
|
||||||
p := testProvider("aws")
|
p := testProvider("aws")
|
||||||
|
|
|
@ -150,6 +150,14 @@ aws_instance.foo:
|
||||||
type = aws_instance
|
type = aws_instance
|
||||||
`
|
`
|
||||||
|
|
||||||
|
const testTerraformInputVarOnlyUnsetStr = `
|
||||||
|
aws_instance.foo:
|
||||||
|
ID = foo
|
||||||
|
bar = baz
|
||||||
|
foo = foovalue
|
||||||
|
type = aws_instance
|
||||||
|
`
|
||||||
|
|
||||||
const testTerraformInputVarsStr = `
|
const testTerraformInputVarsStr = `
|
||||||
aws_instance.bar:
|
aws_instance.bar:
|
||||||
ID = foo
|
ID = foo
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
variable "foo" {}
|
||||||
|
variable "bar" {}
|
||||||
|
|
||||||
|
resource "aws_instance" "foo" {
|
||||||
|
foo = "${var.foo}"
|
||||||
|
bar = "${var.bar}"
|
||||||
|
}
|
Loading…
Reference in New Issue