2023-03-28 18:39:22 +00:00
|
|
|
// Copyright (c) HashiCorp, Inc.
|
2023-08-11 13:12:13 +00:00
|
|
|
// SPDX-License-Identifier: BUSL-1.1
|
2023-03-28 18:39:22 +00:00
|
|
|
|
2020-10-06 15:08:37 +00:00
|
|
|
package consul
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
2021-12-09 23:57:22 +00:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
2020-10-06 15:08:37 +00:00
|
|
|
"github.com/hashicorp/consul/agent/structs"
|
|
|
|
"github.com/hashicorp/consul/testrpc"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestLeader_SystemMetadata_CRUD(t *testing.T) {
|
2020-12-07 18:42:55 +00:00
|
|
|
if testing.Short() {
|
|
|
|
t.Skip("too slow for testing.Short")
|
|
|
|
}
|
|
|
|
|
2020-10-06 15:08:37 +00:00
|
|
|
// This test is a little strange because it is testing behavior that
|
|
|
|
// doesn't have an exposed RPC. We're just testing the full round trip of
|
|
|
|
// raft+fsm For now,
|
|
|
|
|
2020-10-06 18:24:05 +00:00
|
|
|
dir1, srv := testServerWithConfig(t, func(c *Config) {
|
|
|
|
// We disable connect here so we skip inserting intention-migration
|
|
|
|
// related system metadata in the background.
|
|
|
|
c.ConnectEnabled = false
|
|
|
|
})
|
2020-10-06 15:08:37 +00:00
|
|
|
defer os.RemoveAll(dir1)
|
|
|
|
defer srv.Shutdown()
|
|
|
|
codec := rpcClient(t, srv)
|
|
|
|
defer codec.Close()
|
|
|
|
|
|
|
|
testrpc.WaitForLeader(t, srv.RPC, "dc1")
|
|
|
|
|
|
|
|
state := srv.fsm.State()
|
|
|
|
|
2022-01-04 16:24:56 +00:00
|
|
|
// Initially has no entries
|
2020-10-06 15:08:37 +00:00
|
|
|
_, entries, err := state.SystemMetadataList(nil)
|
|
|
|
require.NoError(t, err)
|
2022-01-04 16:24:56 +00:00
|
|
|
require.Len(t, entries, 0)
|
2020-10-06 15:08:37 +00:00
|
|
|
|
|
|
|
// Create 3
|
2023-04-18 15:03:05 +00:00
|
|
|
require.NoError(t, srv.SetSystemMetadataKey("key1", "val1"))
|
|
|
|
require.NoError(t, srv.SetSystemMetadataKey("key2", "val2"))
|
|
|
|
require.NoError(t, srv.SetSystemMetadataKey("key3", ""))
|
2020-10-06 15:08:37 +00:00
|
|
|
|
|
|
|
mapify := func(entries []*structs.SystemMetadataEntry) map[string]string {
|
|
|
|
m := make(map[string]string)
|
|
|
|
for _, entry := range entries {
|
|
|
|
m[entry.Key] = entry.Value
|
|
|
|
}
|
|
|
|
return m
|
|
|
|
}
|
|
|
|
|
|
|
|
_, entries, err = state.SystemMetadataList(nil)
|
|
|
|
require.NoError(t, err)
|
2022-01-04 16:24:56 +00:00
|
|
|
require.Len(t, entries, 3)
|
2020-10-06 15:08:37 +00:00
|
|
|
|
|
|
|
require.Equal(t, map[string]string{
|
2022-01-04 16:24:56 +00:00
|
|
|
"key1": "val1",
|
|
|
|
"key2": "val2",
|
|
|
|
"key3": "",
|
2020-10-06 15:08:37 +00:00
|
|
|
}, mapify(entries))
|
|
|
|
|
|
|
|
// Update one and delete one.
|
2023-04-18 15:03:05 +00:00
|
|
|
require.NoError(t, srv.SetSystemMetadataKey("key3", "val3"))
|
2020-10-06 18:24:05 +00:00
|
|
|
require.NoError(t, srv.deleteSystemMetadataKey("key1"))
|
2020-10-06 15:08:37 +00:00
|
|
|
|
|
|
|
_, entries, err = state.SystemMetadataList(nil)
|
|
|
|
require.NoError(t, err)
|
2022-01-04 16:24:56 +00:00
|
|
|
require.Len(t, entries, 2)
|
2020-10-06 15:08:37 +00:00
|
|
|
|
|
|
|
require.Equal(t, map[string]string{
|
2022-01-04 16:24:56 +00:00
|
|
|
"key2": "val2",
|
|
|
|
"key3": "val3",
|
2020-10-06 15:08:37 +00:00
|
|
|
}, mapify(entries))
|
|
|
|
}
|