mirror of
https://github.com/status-im/consul.git
synced 2025-01-18 17:52:17 +00:00
a7774a9538
As the V2 architecture hinges on eventual consistency and controllers reconciling the existing state in response to writes, there are potential issues we could run into regarding ordering and timing of operations. We want to be able to guarantee that given a set of resources the system will always eventually get to the desired correct state. The order of resource writes and delays in performing those writes should not alter the final outcome of reaching the desired state. To that end, this commit introduces arbitrary randomized delays before performing resources writes into the `resourcetest.Client`. Its `PublishResources` method was already randomizing the order of resource writes. By default, no delay is added to normal writes and deletes but tests can opt-in via either passing hard coded options when creating the `resourcetest.Client` or using the `resourcetest.ConfigureTestCLIFlags` function to allow processing of CLI parameters. In addition to allowing configurability of the request delay min and max, the client also has a configurable random number generator seed. When Using the CLI parameter helpers, a test log will be written noting the currently used settings. If the test fails then you can reproduce the same delays and order randomizations by providing the seed during the previous test failure.
53 lines
1.7 KiB
Go
53 lines
1.7 KiB
Go
// Copyright (c) HashiCorp, Inc.
|
|
// SPDX-License-Identifier: BUSL-1.1
|
|
|
|
package catalogtest
|
|
|
|
import (
|
|
"testing"
|
|
|
|
svctest "github.com/hashicorp/consul/agent/grpc-external/services/resource/testing"
|
|
"github.com/hashicorp/consul/internal/catalog"
|
|
"github.com/hashicorp/consul/internal/catalog/internal/controllers"
|
|
"github.com/hashicorp/consul/internal/controller"
|
|
"github.com/hashicorp/consul/internal/resource/reaper"
|
|
rtest "github.com/hashicorp/consul/internal/resource/resourcetest"
|
|
"github.com/hashicorp/consul/proto-public/pbresource"
|
|
"github.com/hashicorp/consul/sdk/testutil"
|
|
)
|
|
|
|
var (
|
|
clientOpts = rtest.ConfigureTestCLIFlags()
|
|
)
|
|
|
|
func runInMemResourceServiceAndControllers(t *testing.T, deps controllers.Dependencies) pbresource.ResourceServiceClient {
|
|
t.Helper()
|
|
|
|
ctx := testutil.TestContext(t)
|
|
|
|
// Create the in-mem resource service
|
|
client := svctest.RunResourceService(t, catalog.RegisterTypes)
|
|
|
|
// Setup/Run the controller manager
|
|
mgr := controller.NewManager(client, testutil.Logger(t))
|
|
catalog.RegisterControllers(mgr, deps)
|
|
|
|
// We also depend on the reaper to take care of cleaning up owned health statuses and
|
|
// service endpoints so we must enable that controller as well
|
|
reaper.RegisterControllers(mgr)
|
|
mgr.SetRaftLeader(true)
|
|
go mgr.Run(ctx)
|
|
|
|
return client
|
|
}
|
|
|
|
func TestControllers_Integration(t *testing.T) {
|
|
client := runInMemResourceServiceAndControllers(t, catalog.DefaultControllerDependencies())
|
|
RunCatalogV2Beta1IntegrationTest(t, client, clientOpts.ClientOptions(t)...)
|
|
}
|
|
|
|
func TestControllers_Lifecycle(t *testing.T) {
|
|
client := runInMemResourceServiceAndControllers(t, catalog.DefaultControllerDependencies())
|
|
RunCatalogV2Beta1LifecycleIntegrationTest(t, client, clientOpts.ClientOptions(t)...)
|
|
}
|