re-add test lost in merge
This commit is contained in:
parent
b860b40127
commit
74ae34865d
|
@ -11117,6 +11117,66 @@ resource "aws_instance" "cbd" {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestContext2Apply_moduleDependsOn(t *testing.T) {
|
||||||
|
m := testModule(t, "apply-module-depends-on")
|
||||||
|
|
||||||
|
p := testProvider("test")
|
||||||
|
p.ReadDataSourceResponse = providers.ReadDataSourceResponse{
|
||||||
|
State: cty.ObjectVal(map[string]cty.Value{
|
||||||
|
"id": cty.StringVal("data"),
|
||||||
|
"foo": cty.NullVal(cty.String),
|
||||||
|
}),
|
||||||
|
}
|
||||||
|
p.DiffFn = testDiffFn
|
||||||
|
|
||||||
|
// each instance being applied should happen in sequential order
|
||||||
|
applied := int64(0)
|
||||||
|
|
||||||
|
p.ApplyResourceChangeFn = func(req providers.ApplyResourceChangeRequest) (resp providers.ApplyResourceChangeResponse) {
|
||||||
|
state := req.PlannedState.AsValueMap()
|
||||||
|
num, _ := state["num"].AsBigFloat().Float64()
|
||||||
|
ord := int64(num)
|
||||||
|
if !atomic.CompareAndSwapInt64(&applied, ord-1, ord) {
|
||||||
|
actual := atomic.LoadInt64(&applied)
|
||||||
|
resp.Diagnostics = resp.Diagnostics.Append(fmt.Errorf("instance %d was applied after %d", ord, actual))
|
||||||
|
}
|
||||||
|
|
||||||
|
state["id"] = cty.StringVal(fmt.Sprintf("test_%d", ord))
|
||||||
|
resp.NewState = cty.ObjectVal(state)
|
||||||
|
|
||||||
|
return resp
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx := testContext2(t, &ContextOpts{
|
||||||
|
Config: m,
|
||||||
|
Providers: map[addrs.Provider]providers.Factory{
|
||||||
|
addrs.NewDefaultProvider("test"): testProviderFuncFixed(p),
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
_, diags := ctx.Plan()
|
||||||
|
if diags.HasErrors() {
|
||||||
|
t.Fatal(diags.ErrWithWarnings())
|
||||||
|
}
|
||||||
|
|
||||||
|
_, diags = ctx.Apply()
|
||||||
|
if diags.HasErrors() {
|
||||||
|
t.Fatal(diags.ErrWithWarnings())
|
||||||
|
}
|
||||||
|
|
||||||
|
// run the plan again to ensure that data sources are not going to be re-read
|
||||||
|
plan, diags := ctx.Plan()
|
||||||
|
if diags.HasErrors() {
|
||||||
|
t.Fatal(diags.ErrWithWarnings())
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, res := range plan.Changes.Resources {
|
||||||
|
if res.Action != plans.NoOp {
|
||||||
|
t.Fatalf("expected NoOp, got %s for %s", res.Action, res.Addr)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func TestContext2Apply_moduleSelfReference(t *testing.T) {
|
func TestContext2Apply_moduleSelfReference(t *testing.T) {
|
||||||
m := testModuleInline(t, map[string]string{
|
m := testModuleInline(t, map[string]string{
|
||||||
"main.tf": `
|
"main.tf": `
|
||||||
|
|
Loading…
Reference in New Issue