- 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)
20 lines
701 B
C#
20 lines
701 B
C#
using NATS.Server.TestUtilities;
|
|
|
|
namespace NATS.Server.Tests;
|
|
|
|
public class JetStreamAckRedeliveryTests
|
|
{
|
|
[Fact]
|
|
public async Task Unacked_message_is_redelivered_after_ack_wait()
|
|
{
|
|
await using var fixture = await JetStreamApiFixture.StartWithAckExplicitConsumerAsync(ackWaitMs: 50);
|
|
await fixture.PublishAndGetAckAsync("orders.created", "1");
|
|
|
|
var first = await fixture.FetchAsync("ORDERS", "PULL", batch: 1);
|
|
var second = await fixture.FetchAfterDelayAsync("ORDERS", "PULL", delayMs: 75, batch: 1);
|
|
|
|
second.Messages.Single().Sequence.ShouldBe(first.Messages.Single().Sequence);
|
|
second.Messages.Single().Redelivered.ShouldBeTrue();
|
|
}
|
|
}
|