- git mv JetStreamApiFixture, JetStreamClusterFixture, LeafFixture, Parity utilities, and TestData from NATS.Server.Tests to NATS.Server.TestUtilities - Update namespaces to NATS.Server.TestUtilities (and .Parity sub-ns) - Make fixture classes public for cross-project access - Add PollHelper to replace Task.Delay polling with SemaphoreSlim waits - Refactor all fixture polling loops to use PollHelper - Add 'using NATS.Server.TestUtilities;' to ~75 consuming test files - Rename local fixture duplicates (MetaGroupTestFixture, LeafProtocolTestFixture) to avoid shadowing shared fixtures - Remove TestData entry from NATS.Server.Tests.csproj (moved to TestUtilities)
22 lines
718 B
C#
22 lines
718 B
C#
using NATS.Server.TestUtilities;
|
|
|
|
namespace NATS.Server.Tests;
|
|
|
|
public class JetStreamClusterControlApiTests
|
|
{
|
|
[Fact]
|
|
public async Task Stream_leader_stepdown_and_meta_stepdown_endpoints_return_success_shape()
|
|
{
|
|
await using var fx = await JetStreamClusterFixture.StartAsync(nodes: 3);
|
|
|
|
var create = await fx.CreateStreamAsync("ORDERS", ["orders.*"], replicas: 3);
|
|
create.Error.ShouldBeNull();
|
|
|
|
var streamStepdown = await fx.RequestAsync("$JS.API.STREAM.LEADER.STEPDOWN.ORDERS", "{}");
|
|
streamStepdown.Success.ShouldBeTrue();
|
|
|
|
var metaStepdown = await fx.RequestAsync("$JS.API.META.LEADER.STEPDOWN", "{}");
|
|
metaStepdown.Success.ShouldBeTrue();
|
|
}
|
|
}
|