- 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)
25 lines
820 B
C#
25 lines
820 B
C#
using NATS.Server.JetStream.Models;
|
|
using NATS.Server.TestUtilities;
|
|
|
|
namespace NATS.Server.Tests;
|
|
|
|
public class JetStreamStreamPolicyRuntimeTests
|
|
{
|
|
[Fact]
|
|
public async Task Discard_new_rejects_publish_when_max_bytes_exceeded()
|
|
{
|
|
// Each message = subject("s.a"=3) + payload(2) + overhead(16) = 21 bytes.
|
|
// MaxBytes=25 holds exactly one message; second publish is rejected.
|
|
await using var fx = await JetStreamApiFixture.StartWithStreamConfigAsync(new StreamConfig
|
|
{
|
|
Name = "S",
|
|
Subjects = ["s.*"],
|
|
MaxBytes = 25,
|
|
Discard = DiscardPolicy.New,
|
|
});
|
|
|
|
(await fx.PublishAndGetAckAsync("s.a", "12")).ErrorCode.ShouldBeNull();
|
|
(await fx.PublishAndGetAckAsync("s.a", "34")).ErrorCode.ShouldNotBeNull();
|
|
}
|
|
}
|