2023-03-28 20:12:30 +01:00
|
|
|
// Copyright (c) HashiCorp, Inc.
|
2023-08-11 09:12:13 -04:00
|
|
|
// SPDX-License-Identifier: BUSL-1.1
|
2023-03-28 20:12:30 +01:00
|
|
|
|
2020-06-16 12:54:27 -04:00
|
|
|
package role
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
|
|
|
"fmt"
|
2022-11-10 10:26:01 -06:00
|
|
|
"os"
|
2020-06-16 12:54:27 -04:00
|
|
|
"path"
|
|
|
|
"path/filepath"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/hashicorp/consul/api"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
// update allows golden files to be updated based on the current output.
|
|
|
|
var update = flag.Bool("update", false, "update golden files")
|
|
|
|
|
|
|
|
// golden reads and optionally writes the expected data to the golden file,
|
|
|
|
// returning the contents as a string.
|
|
|
|
func golden(t *testing.T, name, got string) string {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
golden := filepath.Join("testdata", name+".golden")
|
|
|
|
if *update && got != "" {
|
2022-11-10 10:26:01 -06:00
|
|
|
err := os.WriteFile(golden, []byte(got), 0644)
|
2020-06-16 12:54:27 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
}
|
|
|
|
|
2022-11-10 10:26:01 -06:00
|
|
|
expected, err := os.ReadFile(golden)
|
2020-06-16 12:54:27 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
return string(expected)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestFormatRole(t *testing.T) {
|
|
|
|
type testCase struct {
|
|
|
|
role api.ACLRole
|
|
|
|
overrideGoldenName string
|
|
|
|
}
|
|
|
|
|
|
|
|
cases := map[string]testCase{
|
|
|
|
"basic": {
|
|
|
|
role: api.ACLRole{
|
|
|
|
ID: "bd6c9fb0-2d1a-4b96-acaf-669f5d7e7852",
|
|
|
|
Name: "basic",
|
|
|
|
Description: "test role",
|
|
|
|
Hash: []byte{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'},
|
|
|
|
CreateIndex: 42,
|
|
|
|
ModifyIndex: 100,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"complex": {
|
|
|
|
role: api.ACLRole{
|
|
|
|
ID: "c29c4ee4-bca6-474e-be37-7d9606f9582a",
|
|
|
|
Name: "complex",
|
|
|
|
Namespace: "foo",
|
|
|
|
Description: "test role complex",
|
|
|
|
Hash: []byte{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'},
|
|
|
|
CreateIndex: 5,
|
|
|
|
ModifyIndex: 10,
|
|
|
|
Policies: []*api.ACLLink{
|
2020-06-16 13:19:31 -04:00
|
|
|
{
|
2020-06-16 12:54:27 -04:00
|
|
|
ID: "beb04680-815b-4d7c-9e33-3d707c24672c",
|
|
|
|
Name: "hobbiton",
|
|
|
|
},
|
2020-06-16 13:19:31 -04:00
|
|
|
{
|
2020-06-16 12:54:27 -04:00
|
|
|
ID: "18788457-584c-4812-80d3-23d403148a90",
|
|
|
|
Name: "bywater",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServiceIdentities: []*api.ACLServiceIdentity{
|
2020-06-16 13:19:31 -04:00
|
|
|
{
|
2020-06-16 12:54:27 -04:00
|
|
|
ServiceName: "gardener",
|
|
|
|
Datacenters: []string{"middleearth-northwest"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
NodeIdentities: []*api.ACLNodeIdentity{
|
2020-06-16 13:19:31 -04:00
|
|
|
{
|
2020-06-16 12:54:27 -04:00
|
|
|
NodeName: "bagend",
|
|
|
|
Datacenter: "middleearth-northwest",
|
|
|
|
},
|
|
|
|
},
|
2023-09-08 08:45:24 -04:00
|
|
|
TemplatedPolicies: []*api.ACLTemplatedPolicy{
|
|
|
|
{
|
|
|
|
TemplateName: api.ACLTemplatedPolicyServiceName,
|
|
|
|
TemplateVariables: &api.ACLTemplatedPolicyVariables{Name: "gardener"},
|
|
|
|
Datacenters: []string{"middleearth-northwest", "somewhere-east"},
|
|
|
|
},
|
|
|
|
{TemplateName: api.ACLTemplatedPolicyNodeName, TemplateVariables: &api.ACLTemplatedPolicyVariables{Name: "bagend"}},
|
|
|
|
},
|
2020-06-16 12:54:27 -04:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
formatters := map[string]Formatter{
|
|
|
|
"pretty": newPrettyFormatter(false),
|
|
|
|
"pretty-meta": newPrettyFormatter(true),
|
|
|
|
// the JSON formatter ignores the showMeta
|
|
|
|
"json": newJSONFormatter(false),
|
|
|
|
}
|
|
|
|
|
|
|
|
for name, tcase := range cases {
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
for fmtName, formatter := range formatters {
|
|
|
|
t.Run(fmtName, func(t *testing.T) {
|
|
|
|
actual, err := formatter.FormatRole(&tcase.role)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
gName := fmt.Sprintf("%s.%s", name, fmtName)
|
|
|
|
if tcase.overrideGoldenName != "" {
|
|
|
|
gName = tcase.overrideGoldenName
|
|
|
|
}
|
|
|
|
|
|
|
|
expected := golden(t, path.Join("FormatRole", gName), actual)
|
|
|
|
require.Equal(t, expected, actual)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-09-08 08:45:24 -04:00
|
|
|
func TestFormatRoleList(t *testing.T) {
|
2020-06-16 12:54:27 -04:00
|
|
|
type testCase struct {
|
|
|
|
roles []*api.ACLRole
|
|
|
|
overrideGoldenName string
|
|
|
|
}
|
|
|
|
|
|
|
|
cases := map[string]testCase{
|
|
|
|
"basic": {
|
|
|
|
roles: []*api.ACLRole{
|
2020-06-16 13:19:31 -04:00
|
|
|
{
|
2020-06-16 12:54:27 -04:00
|
|
|
ID: "bd6c9fb0-2d1a-4b96-acaf-669f5d7e7852",
|
|
|
|
Name: "basic",
|
|
|
|
Description: "test role",
|
|
|
|
Hash: []byte{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'},
|
|
|
|
CreateIndex: 42,
|
|
|
|
ModifyIndex: 100,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"complex": {
|
|
|
|
roles: []*api.ACLRole{
|
2020-06-16 13:19:31 -04:00
|
|
|
{
|
2020-06-16 12:54:27 -04:00
|
|
|
ID: "c29c4ee4-bca6-474e-be37-7d9606f9582a",
|
|
|
|
Name: "complex",
|
|
|
|
Namespace: "foo",
|
|
|
|
Description: "test role complex",
|
|
|
|
Hash: []byte{'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'},
|
|
|
|
CreateIndex: 5,
|
|
|
|
ModifyIndex: 10,
|
|
|
|
Policies: []*api.ACLLink{
|
2020-06-16 13:19:31 -04:00
|
|
|
{
|
2020-06-16 12:54:27 -04:00
|
|
|
ID: "beb04680-815b-4d7c-9e33-3d707c24672c",
|
|
|
|
Name: "hobbiton",
|
|
|
|
},
|
2020-06-16 13:19:31 -04:00
|
|
|
{
|
2020-06-16 12:54:27 -04:00
|
|
|
ID: "18788457-584c-4812-80d3-23d403148a90",
|
|
|
|
Name: "bywater",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
ServiceIdentities: []*api.ACLServiceIdentity{
|
2020-06-16 13:19:31 -04:00
|
|
|
{
|
2020-06-16 12:54:27 -04:00
|
|
|
ServiceName: "gardener",
|
|
|
|
Datacenters: []string{"middleearth-northwest"},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
NodeIdentities: []*api.ACLNodeIdentity{
|
2020-06-16 13:19:31 -04:00
|
|
|
{
|
2020-06-16 12:54:27 -04:00
|
|
|
NodeName: "bagend",
|
|
|
|
Datacenter: "middleearth-northwest",
|
|
|
|
},
|
|
|
|
},
|
2023-09-08 08:45:24 -04:00
|
|
|
TemplatedPolicies: []*api.ACLTemplatedPolicy{
|
|
|
|
{TemplateName: api.ACLTemplatedPolicyServiceName, TemplateVariables: &api.ACLTemplatedPolicyVariables{Name: "gardener"}},
|
|
|
|
{TemplateName: api.ACLTemplatedPolicyNodeName, TemplateVariables: &api.ACLTemplatedPolicyVariables{Name: "bagend"}},
|
|
|
|
},
|
2020-06-16 12:54:27 -04:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
formatters := map[string]Formatter{
|
|
|
|
"pretty": newPrettyFormatter(false),
|
|
|
|
"pretty-meta": newPrettyFormatter(true),
|
|
|
|
// the JSON formatter ignores the showMeta
|
|
|
|
"json": newJSONFormatter(false),
|
|
|
|
}
|
|
|
|
|
|
|
|
for name, tcase := range cases {
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
for fmtName, formatter := range formatters {
|
|
|
|
t.Run(fmtName, func(t *testing.T) {
|
|
|
|
actual, err := formatter.FormatRoleList(tcase.roles)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
gName := fmt.Sprintf("%s.%s", name, fmtName)
|
|
|
|
if tcase.overrideGoldenName != "" {
|
|
|
|
gName = tcase.overrideGoldenName
|
|
|
|
}
|
|
|
|
|
|
|
|
expected := golden(t, path.Join("FormatRoleList", gName), actual)
|
|
|
|
require.Equal(t, expected, actual)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|