opentofu/internal/checks/state_init.go
Kuba Martin ebcf7455eb
Rename root module name. (#4)
* Rename module name from "github.com/hashicorp/terraform" to "github.com/placeholderplaceholderplaceholder/opentf".

Signed-off-by: Jakub Martin <kubam@spacelift.io>

* Gofmt.

Signed-off-by: Jakub Martin <kubam@spacelift.io>

* Regenerate protobuf.

Signed-off-by: Jakub Martin <kubam@spacelift.io>

* Fix comments.

Signed-off-by: Jakub Martin <kubam@spacelift.io>

* Undo issue and pull request link changes.

Signed-off-by: Jakub Martin <kubam@spacelift.io>

* Undo comment changes.

Signed-off-by: Jakub Martin <kubam@spacelift.io>

* Fix comment.

Signed-off-by: Jakub Martin <kubam@spacelift.io>

* Undo some link changes.

Signed-off-by: Jakub Martin <kubam@spacelift.io>

* make generate && make protobuf

Signed-off-by: Jakub Martin <kubam@spacelift.io>

---------

Signed-off-by: Jakub Martin <kubam@spacelift.io>
2023-08-17 14:45:11 +02:00

113 lines
2.7 KiB
Go

// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: MPL-2.0
package checks
import (
"github.com/placeholderplaceholderplaceholder/opentf/internal/addrs"
"github.com/placeholderplaceholderplaceholder/opentf/internal/configs"
)
func initialStatuses(cfg *configs.Config) addrs.Map[addrs.ConfigCheckable, *configCheckableState] {
ret := addrs.MakeMap[addrs.ConfigCheckable, *configCheckableState]()
if cfg == nil {
// This should not happen in normal use, but can arise in some
// unit tests that are not working with a full configuration and
// don't care about checks.
return ret
}
collectInitialStatuses(ret, cfg)
return ret
}
func collectInitialStatuses(into addrs.Map[addrs.ConfigCheckable, *configCheckableState], cfg *configs.Config) {
moduleAddr := cfg.Path
for _, rc := range cfg.Module.ManagedResources {
addr := rc.Addr().InModule(moduleAddr)
collectInitialStatusForResource(into, addr, rc)
}
for _, rc := range cfg.Module.DataResources {
addr := rc.Addr().InModule(moduleAddr)
collectInitialStatusForResource(into, addr, rc)
}
for _, oc := range cfg.Module.Outputs {
addr := oc.Addr().InModule(moduleAddr)
ct := len(oc.Preconditions)
if ct == 0 {
// We just ignore output values that don't declare any checks.
continue
}
st := &configCheckableState{}
st.checkTypes = map[addrs.CheckRuleType]int{
addrs.OutputPrecondition: ct,
}
into.Put(addr, st)
}
for _, c := range cfg.Module.Checks {
addr := c.Addr().InModule(moduleAddr)
st := &configCheckableState{
checkTypes: map[addrs.CheckRuleType]int{
addrs.CheckAssertion: len(c.Asserts),
},
}
if c.DataResource != nil {
st.checkTypes[addrs.CheckDataResource] = 1
}
into.Put(addr, st)
}
for _, v := range cfg.Module.Variables {
addr := v.Addr().InModule(moduleAddr)
vs := len(v.Validations)
if vs == 0 {
continue
}
st := &configCheckableState{}
st.checkTypes = map[addrs.CheckRuleType]int{
addrs.InputValidation: vs,
}
into.Put(addr, st)
}
// Must also visit child modules to collect everything
for _, child := range cfg.Children {
collectInitialStatuses(into, child)
}
}
func collectInitialStatusForResource(into addrs.Map[addrs.ConfigCheckable, *configCheckableState], addr addrs.ConfigResource, rc *configs.Resource) {
if (len(rc.Preconditions) + len(rc.Postconditions)) == 0 {
// Don't bother with any resource that doesn't have at least
// one condition.
return
}
st := &configCheckableState{
checkTypes: make(map[addrs.CheckRuleType]int),
}
if ct := len(rc.Preconditions); ct > 0 {
st.checkTypes[addrs.ResourcePrecondition] = ct
}
if ct := len(rc.Postconditions); ct > 0 {
st.checkTypes[addrs.ResourcePostcondition] = ct
}
into.Put(addr, st)
}