Files
trivy/pkg/iac/scanners/terraform/deterministic_test.go
2025-07-29 07:13:54 +00:00

44 lines
741 B
Go

package terraform
import (
"strings"
"testing"
"github.com/stretchr/testify/require"
"github.com/aquasecurity/trivy/internal/testutil"
"github.com/aquasecurity/trivy/pkg/iac/rego"
)
func Test_DeterministicResults(t *testing.T) {
fsys := testutil.CreateFS(t, map[string]string{
"first.tf": `
resource "aws_s3_bucket" "test" {
for_each = other.thing
}
`,
"second.tf": `
resource "other" "thing" {
for_each = local.list
}
`,
"third.tf": `
locals {
list = {
a = 1,
b = 2,
}
}
`,
})
for range 100 {
results, err := scanFS(fsys, ".",
rego.WithPolicyReader(strings.NewReader(emptyBucketCheck)),
rego.WithPolicyNamespaces("user"),
)
require.NoError(t, err)
require.Len(t, results.GetFailed(), 2)
}
}