consul/internal
hc-github-team-consul-core da2a57239e
Backport of Introduce randomized timings and reproducible randomization into controller integration tests. into release/1.17.x (#19575)
Introduce randomized timings and reproducible randomization into controller integration tests.

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.

# Conflicts:
#	internal/catalog/catalogtest/run_test.go
#	internal/catalog/catalogtest/test_integration_v2beta1.go
#	test/integration/consul-container/test/catalog/catalog_test.go

Co-authored-by: Matt Keeler <mjkeeler7@gmail.com>
2023-11-08 16:39:28 -05:00
..
auth Backport of temporarily disallow L7 traffic permissions into release/1.17.x (#19488) 2023-11-02 18:36:38 +00:00
catalog Backport of Introduce randomized timings and reproducible randomization into controller integration tests. into release/1.17.x (#19575) 2023-11-08 16:39:28 -05:00
controller
go-sso
mesh Backport of [NET-6305] xds: Ensure v2 route match and protocol are populated for gRPC into release/1.17.x (#19366) 2023-10-25 19:12:18 +00:00
protohcl
protoutil
radix
resource Backport of Introduce randomized timings and reproducible randomization into controller integration tests. into release/1.17.x (#19575) 2023-11-08 16:39:28 -05:00
resourcehcl
storage
tenancy Add namespace read write tests (#19173) 2023-10-13 12:03:06 -04:00
testing/golden Backport of NET-5397 - wire up destination golden tests from sidecar-proxy controller for xds controller and xdsv2 into release/1.17.x (#19350) 2023-10-24 16:48:10 +00:00
tools