mirror of
https://github.com/status-im/consul.git
synced 2025-01-24 12:40:17 +00:00
6c4b83c119
Previously calling `index.New` would return an object with the index information such as the Indexer, whether it was required, and the name of the index as well as a radix tree to store indexed data. Now the main `Index` type doesn’t contain the radix tree for indexed data. Instead the `IndexedData` method can be used to combine the main `Index` with a radix tree in the `IndexedData` structure. The cache still only allows configuring the `Index` type and will invoke the `IndexedData` method on the provided indexes to get the structure that the cache can use for actual data management. All of this makes it now safe to reuse the `index.Index` types.
97 lines
2.2 KiB
Go
97 lines
2.2 KiB
Go
// Copyright (c) HashiCorp, Inc.
|
|
// SPDX-License-Identifier: BUSL-1.1
|
|
|
|
package indexers
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/hashicorp/consul/internal/controller/cache/index"
|
|
"github.com/hashicorp/consul/internal/controller/cache/indexers/indexersmock"
|
|
"github.com/hashicorp/consul/internal/resource/resourcetest"
|
|
"github.com/hashicorp/consul/proto-public/pbresource"
|
|
pbdemo "github.com/hashicorp/consul/proto/private/pbdemo/v1"
|
|
"github.com/hashicorp/consul/proto/private/prototest"
|
|
)
|
|
|
|
func TestIDIndex(t *testing.T) {
|
|
idx := IDIndex("test", index.IndexRequired).IndexedData()
|
|
|
|
r1 := resourcetest.Resource(pbdemo.AlbumType, "foo").
|
|
WithTenancy(&pbresource.Tenancy{
|
|
Partition: "default",
|
|
Namespace: "default",
|
|
}).
|
|
WithData(t, &pbdemo.Album{
|
|
Name: "foo",
|
|
}).
|
|
Build()
|
|
|
|
txn := idx.Txn()
|
|
require.NoError(t, txn.Insert(r1))
|
|
txn.Commit()
|
|
|
|
out, err := idx.Txn().Get(r1.Id)
|
|
require.NoError(t, err)
|
|
prototest.AssertDeepEqual(t, r1, out)
|
|
}
|
|
|
|
func TestOwnerIndex(t *testing.T) {
|
|
idx := OwnerIndex("test", index.IndexRequired).IndexedData()
|
|
|
|
r1 := resourcetest.Resource(pbdemo.AlbumType, "foo").
|
|
WithTenancy(&pbresource.Tenancy{
|
|
Partition: "default",
|
|
Namespace: "default",
|
|
}).
|
|
WithData(t, &pbdemo.Album{
|
|
Name: "foo",
|
|
}).
|
|
WithOwner(&pbresource.ID{
|
|
Type: pbdemo.ArtistType,
|
|
Tenancy: &pbresource.Tenancy{
|
|
Partition: "default",
|
|
Namespace: "default",
|
|
},
|
|
}).
|
|
Build()
|
|
|
|
txn := idx.Txn()
|
|
require.NoError(t, txn.Insert(r1))
|
|
txn.Commit()
|
|
|
|
out, err := idx.Txn().Get(r1.Owner)
|
|
require.NoError(t, err)
|
|
prototest.AssertDeepEqual(t, r1, out)
|
|
}
|
|
|
|
func TestSingleIDOrRefIndex(t *testing.T) {
|
|
getRef := indexersmock.NewGetSingleRefOrID(t)
|
|
|
|
idx := SingleIDOrRefIndex("test", getRef.Execute).IndexedData()
|
|
|
|
r1 := resourcetest.Resource(pbdemo.AlbumType, "foo").Build()
|
|
ref := &pbresource.Reference{
|
|
Type: pbdemo.ArtistType,
|
|
Tenancy: &pbresource.Tenancy{
|
|
Partition: "default",
|
|
Namespace: "default",
|
|
},
|
|
Name: "foo",
|
|
}
|
|
|
|
getRef.EXPECT().Execute(r1).
|
|
Return(ref).
|
|
Once()
|
|
|
|
txn := idx.Txn()
|
|
require.NoError(t, txn.Insert(r1))
|
|
txn.Commit()
|
|
|
|
out, err := idx.Txn().Get(ref)
|
|
require.NoError(t, err)
|
|
prototest.AssertDeepEqual(t, r1, out)
|
|
}
|