vault/audit/sink_metric_timer_test.go
Peter Wilson 8bee54c89d
VAULT-24452: audit refactor (#26460)
* Refactor audit code into audit package
* remove builtin/audit
* removed unrequired files
2024-04-18 08:25:04 +01:00

69 lines
1.6 KiB
Go

// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: BUSL-1.1
package audit
import (
"testing"
"github.com/hashicorp/eventlogger"
"github.com/hashicorp/vault/internal/observability/event"
"github.com/stretchr/testify/require"
)
// TestNewSinkMetricTimer ensures that parameters are checked correctly and errors
// reported as expected when attempting to create a sinkMetricTimer.
func TestNewSinkMetricTimer(t *testing.T) {
t.Parallel()
tests := map[string]struct {
name string
node eventlogger.Node
isErrorExpected bool
expectedErrorMessage string
}{
"happy": {
name: "foo",
node: &event.FileSink{},
isErrorExpected: false,
},
"no-name": {
name: "",
isErrorExpected: true,
expectedErrorMessage: "name is required: invalid internal parameter",
},
"no-node": {
name: "foo",
node: nil,
isErrorExpected: true,
expectedErrorMessage: "sink node is required: invalid internal parameter",
},
"bad-node": {
name: "foo",
node: &entryFormatter{},
isErrorExpected: true,
expectedErrorMessage: "sink node must be of type 'sink': invalid internal parameter",
},
}
for name, tc := range tests {
name := name
tc := tc
t.Run(name, func(t *testing.T) {
t.Parallel()
m, err := newSinkMetricTimer(tc.name, tc.node)
switch {
case tc.isErrorExpected:
require.Error(t, err)
require.EqualError(t, err, tc.expectedErrorMessage)
require.Nil(t, m)
default:
require.NoError(t, err)
require.NotNil(t, m)
}
})
}
}