Fix E2E test gaps and add comprehensive E2E + parity test suites

- Fix pull consumer fetch: send original stream subject in HMSG (not inbox)
  so NATS client distinguishes data messages from control messages
- Fix MaxAge expiry: add background timer in StreamManager for periodic pruning
- Fix JetStream wire format: Go-compatible anonymous objects with string enums,
  proper offset-based pagination for stream/consumer list APIs
- Add 42 E2E black-box tests (core messaging, auth, TLS, accounts, JetStream)
- Add ~1000 parity tests across all subsystems (gaps closure)
- Update gap inventory docs to reflect implementation status
This commit is contained in:
Joseph Doherty
2026-03-12 14:09:23 -04:00
parent 79c1ee8776
commit c30e67a69d
226 changed files with 17801 additions and 709 deletions

View File

@@ -5,9 +5,46 @@ namespace NATS.Server.Protocol;
public static class NatsProtocol
{
public const int MaxControlLineSize = 4096;
public const int MaxControlLineSnippetSize = 128;
public const int ProtoSnippetSize = 32;
public const int MaxPayloadSize = 1024 * 1024; // 1MB
public const int MaxPayloadMaxSize = 8 * 1024 * 1024; // 8MB
public const long MaxPendingSize = 64 * 1024 * 1024; // 64MB default max pending
public const string DefaultHost = "0.0.0.0";
public const int DefaultPort = 4222;
public const int DefaultHttpPort = 8222;
public const string DefaultHttpBasePath = "/";
public const int DefaultRoutePoolSize = 3;
public const int DefaultLeafNodePort = 7422;
public const int DefaultMaxConnections = 64 * 1024;
public const int DefaultPingMaxOut = 2;
public const int DefaultMaxClosedClients = 10_000;
public const int DefaultConnectErrorReports = 3600;
public const int DefaultReconnectErrorReports = 1;
public const int DefaultAllowResponseMaxMsgs = 1;
public const int DefaultServiceLatencySampling = 100;
public const string DefaultSystemAccount = "$SYS";
public const string DefaultGlobalAccount = "$G";
public static readonly TimeSpan TlsTimeout = TimeSpan.FromSeconds(2);
public static readonly TimeSpan DefaultTlsHandshakeFirstFallbackDelay = TimeSpan.FromMilliseconds(50);
public static readonly TimeSpan AuthTimeout = TimeSpan.FromSeconds(2);
public static readonly TimeSpan DefaultRouteConnect = TimeSpan.FromSeconds(1);
public static readonly TimeSpan DefaultRouteConnectMax = TimeSpan.FromSeconds(30);
public static readonly TimeSpan DefaultRouteReconnect = TimeSpan.FromSeconds(1);
public static readonly TimeSpan DefaultRouteDial = TimeSpan.FromSeconds(1);
public static readonly TimeSpan DefaultLeafNodeReconnect = TimeSpan.FromSeconds(1);
public static readonly TimeSpan DefaultLeafTlsTimeout = TimeSpan.FromSeconds(2);
public static readonly TimeSpan DefaultLeafNodeInfoWait = TimeSpan.FromSeconds(1);
public static readonly TimeSpan DefaultRttMeasurementInterval = TimeSpan.FromHours(1);
public static readonly TimeSpan DefaultAllowResponseExpiration = TimeSpan.FromMinutes(2);
public static readonly TimeSpan DefaultServiceExportResponseThreshold = TimeSpan.FromMinutes(2);
public static readonly TimeSpan DefaultAccountFetchTimeout = TimeSpan.FromMilliseconds(1900);
public static readonly TimeSpan DefaultPingInterval = TimeSpan.FromMinutes(2);
public static readonly TimeSpan DefaultFlushDeadline = TimeSpan.FromSeconds(10);
public static readonly TimeSpan AcceptMinSleep = TimeSpan.FromMilliseconds(10);
public static readonly TimeSpan AcceptMaxSleep = TimeSpan.FromSeconds(1);
public static readonly TimeSpan DefaultLameDuckDuration = TimeSpan.FromMinutes(2);
public static readonly TimeSpan DefaultLameDuckGracePeriod = TimeSpan.FromSeconds(10);
public const string Version = "0.1.0";
public const int ProtoVersion = 1;