open-nomad/nomad/state/indexer/time_test.go
James Rasell 0cde3182eb
core: add ACL token expiry state, struct, and RPC handling. (#13718)
The ACL token state schema has been updated to utilise two new
indexes which track expiration of tokens that are configured with
an expiration TTL or time. A new state function allows listing
ACL expired tokens which will be used by internal garbage
collection.

The ACL endpoint has been modified so that all validation happens
within a single function call. This is easier to understand and
see at a glance. The ACL token validation now also includes logic
for expiry TTL and times. The ACL endpoint upsert tests have been
condensed into a single, table driven test.

There is a new token canonicalize which provides a single place
for token canonicalization, rather than logic spread in the RPC
handler.
2022-07-13 15:40:34 +02:00

46 lines
1.1 KiB
Go

package indexer
import (
"testing"
"time"
"github.com/hashicorp/nomad/ci"
"github.com/stretchr/testify/require"
)
func Test_IndexFromTimeQuery(t *testing.T) {
ci.Parallel(t)
testCases := []struct {
inputArg interface{}
expectedOutputBytes []byte
expectedOutputError error
name string
}{
{
inputArg: &TimeQuery{
Value: time.Date(1987, time.April, 13, 8, 3, 0, 0, time.UTC),
},
expectedOutputBytes: []byte{0x0, 0x0, 0x0, 0x0, 0x20, 0x80, 0x9b, 0xb4},
expectedOutputError: nil,
name: "generic test 1",
},
{
inputArg: &TimeQuery{
Value: time.Date(2022, time.April, 27, 14, 12, 0, 0, time.UTC),
},
expectedOutputBytes: []byte{0x0, 0x0, 0x0, 0x0, 0x62, 0x69, 0x4f, 0x30},
expectedOutputError: nil,
name: "generic test 2",
},
}
for _, tc := range testCases {
t.Run(tc.name, func(t *testing.T) {
actualOutput, actualError := IndexFromTimeQuery(tc.inputArg)
require.Equal(t, tc.expectedOutputError, actualError)
require.Equal(t, tc.expectedOutputBytes, actualOutput)
})
}
}