mirror of
https://github.com/hashicorp/vault.git
synced 2025-08-22 15:11:07 +02:00
* Refactor audit code into audit package * remove builtin/audit * removed unrequired files
147 lines
4.1 KiB
Go
147 lines
4.1 KiB
Go
// Copyright (c) HashiCorp, Inc.
|
|
// SPDX-License-Identifier: BUSL-1.1
|
|
|
|
package audit
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/hashicorp/eventlogger"
|
|
"github.com/hashicorp/go-hclog"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
// TestBackend_newFormatterConfig ensures that all the configuration values are
|
|
// parsed correctly when trying to create a new formatterConfig via newFormatterConfig.
|
|
func TestBackend_newFormatterConfig(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
tests := map[string]struct {
|
|
config map[string]string
|
|
want formatterConfig
|
|
wantErr bool
|
|
expectedMessage string
|
|
}{
|
|
"happy-path-json": {
|
|
config: map[string]string{
|
|
"format": JSONFormat.String(),
|
|
"hmac_accessor": "true",
|
|
"log_raw": "true",
|
|
"elide_list_responses": "true",
|
|
},
|
|
want: formatterConfig{
|
|
raw: true,
|
|
hmacAccessor: true,
|
|
elideListResponses: true,
|
|
requiredFormat: "json",
|
|
}, wantErr: false,
|
|
},
|
|
"happy-path-jsonx": {
|
|
config: map[string]string{
|
|
"format": JSONxFormat.String(),
|
|
"hmac_accessor": "true",
|
|
"log_raw": "true",
|
|
"elide_list_responses": "true",
|
|
},
|
|
want: formatterConfig{
|
|
raw: true,
|
|
hmacAccessor: true,
|
|
elideListResponses: true,
|
|
requiredFormat: "jsonx",
|
|
},
|
|
wantErr: false,
|
|
},
|
|
"invalid-format": {
|
|
config: map[string]string{
|
|
"format": " squiggly ",
|
|
"hmac_accessor": "true",
|
|
"log_raw": "true",
|
|
"elide_list_responses": "true",
|
|
},
|
|
want: formatterConfig{},
|
|
wantErr: true,
|
|
expectedMessage: "unsupported \"format\": invalid configuration",
|
|
},
|
|
"invalid-hmac-accessor": {
|
|
config: map[string]string{
|
|
"format": JSONFormat.String(),
|
|
"hmac_accessor": "maybe",
|
|
},
|
|
want: formatterConfig{},
|
|
wantErr: true,
|
|
expectedMessage: "unable to parse \"hmac_accessor\": invalid configuration",
|
|
},
|
|
"invalid-log-raw": {
|
|
config: map[string]string{
|
|
"format": JSONFormat.String(),
|
|
"hmac_accessor": "true",
|
|
"log_raw": "maybe",
|
|
},
|
|
want: formatterConfig{},
|
|
wantErr: true,
|
|
expectedMessage: "unable to parse \"log_raw\": invalid configuration",
|
|
},
|
|
"invalid-elide-bool": {
|
|
config: map[string]string{
|
|
"format": JSONFormat.String(),
|
|
"hmac_accessor": "true",
|
|
"log_raw": "true",
|
|
"elide_list_responses": "maybe",
|
|
},
|
|
want: formatterConfig{},
|
|
wantErr: true,
|
|
expectedMessage: "unable to parse \"elide_list_responses\": invalid configuration",
|
|
},
|
|
"prefix": {
|
|
config: map[string]string{
|
|
"format": JSONFormat.String(),
|
|
"prefix": "foo",
|
|
},
|
|
want: formatterConfig{
|
|
requiredFormat: JSONFormat,
|
|
prefix: "foo",
|
|
hmacAccessor: true,
|
|
},
|
|
},
|
|
}
|
|
for name, tc := range tests {
|
|
name := name
|
|
tc := tc
|
|
t.Run(name, func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
got, err := newFormatterConfig(&NoopHeaderFormatter{}, tc.config)
|
|
if tc.wantErr {
|
|
require.Error(t, err)
|
|
require.EqualError(t, err, tc.expectedMessage)
|
|
} else {
|
|
require.NoError(t, err)
|
|
}
|
|
require.Equal(t, tc.want.requiredFormat, got.requiredFormat)
|
|
require.Equal(t, tc.want.raw, got.raw)
|
|
require.Equal(t, tc.want.elideListResponses, got.elideListResponses)
|
|
require.Equal(t, tc.want.hmacAccessor, got.hmacAccessor)
|
|
require.Equal(t, tc.want.omitTime, got.omitTime)
|
|
require.Equal(t, tc.want.prefix, got.prefix)
|
|
})
|
|
}
|
|
}
|
|
|
|
// TestBackend_configureFormatterNode ensures that configureFormatterNode
|
|
// populates the nodeIDList and nodeMap on backend when given valid config.
|
|
func TestBackend_configureFormatterNode(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
b, err := newBackend(&NoopHeaderFormatter{}, &BackendConfig{
|
|
MountPath: "foo",
|
|
Logger: hclog.NewNullLogger(),
|
|
})
|
|
require.NoError(t, err)
|
|
|
|
require.Len(t, b.nodeIDList, 1)
|
|
require.Len(t, b.nodeMap, 1)
|
|
id := b.nodeIDList[0]
|
|
node := b.nodeMap[id]
|
|
require.Equal(t, eventlogger.NodeTypeFormatter, node.Type())
|
|
}
|