Joseph Doherty
93cf4cf959
Merge branch 'worktree-agent-afa3d16c'
2026-03-01 12:19:43 -05:00
Joseph Doherty
c8657f626e
fix(batch57): add missing constructors to SuperCluster and LeafNode test classes
2026-03-01 12:19:36 -05:00
Joseph Doherty
3ddc5cb1a2
Merge branch 'worktree-agent-aea55702'
...
# Conflicts:
# dotnet/tests/ZB.MOM.NatsNet.Server.IntegrationTests/Helpers/CheckHelper.cs
# dotnet/tests/ZB.MOM.NatsNet.Server.IntegrationTests/Helpers/ConfigHelper.cs
# dotnet/tests/ZB.MOM.NatsNet.Server.IntegrationTests/Helpers/IntegrationTestBase.cs
# dotnet/tests/ZB.MOM.NatsNet.Server.IntegrationTests/Helpers/NatsTestClient.cs
# dotnet/tests/ZB.MOM.NatsNet.Server.IntegrationTests/Helpers/TestCluster.cs
# dotnet/tests/ZB.MOM.NatsNet.Server.IntegrationTests/Helpers/TestServerHelper.cs
# dotnet/tests/ZB.MOM.NatsNet.Server.IntegrationTests/Helpers/TestSuperCluster.cs
2026-03-01 12:18:58 -05:00
Joseph Doherty
6d3f3bd185
Merge branch 'worktree-agent-a2ba16fc'
2026-03-01 12:18:46 -05:00
Joseph Doherty
e0a87ca41f
feat(batch50): merge JetStream cluster 1 tests and fix build errors
...
- Added ShouldSkip() and ServerRuntimeUnavailable to IntegrationTestBase
- Fixed WaitOnPeerCount -> WaitOnClusterReady
- Fixed using -> await using for NatsConnection (IAsyncDisposable)
- Removed duplicate PackageReference entries from csproj
2026-03-01 12:18:40 -05:00
Joseph Doherty
7c3925730e
test(batch54): port 78 MQTT integration tests
2026-03-01 12:16:52 -05:00
Joseph Doherty
61e27879f7
Merge branch 'worktree-agent-a830a417'
...
# Conflicts:
# dotnet/tests/ZB.MOM.NatsNet.Server.IntegrationTests/Helpers/CheckHelper.cs
# dotnet/tests/ZB.MOM.NatsNet.Server.IntegrationTests/Helpers/ConfigHelper.cs
# dotnet/tests/ZB.MOM.NatsNet.Server.IntegrationTests/Helpers/IntegrationTestBase.cs
# dotnet/tests/ZB.MOM.NatsNet.Server.IntegrationTests/Helpers/NatsTestClient.cs
# dotnet/tests/ZB.MOM.NatsNet.Server.IntegrationTests/Helpers/TestCluster.cs
2026-03-01 12:16:28 -05:00
Joseph Doherty
bebff9168a
test(batch57): port 53 SuperCluster and LeafNode integration tests
...
Ports 36 JetStream super-cluster tests from jetstream_super_cluster_test.go,
3 JetStream leaf-node tests from jetstream_leafnode_test.go, and 14 leaf-node
tests from leafnode_test.go into the integration test project. Creates the
required harness infrastructure (TestSuperCluster, TestCluster, IntegrationTestBase,
CheckHelper, ConfigHelper, NatsTestClient, TestServerHelper). All 53 tests are
marked [Fact(Skip = "...")] pending full multi-server cluster runtime.
2026-03-01 12:15:44 -05:00
Joseph Doherty
8db4fccc95
test(batch50): port 118 JetStream cluster 1 integration tests
...
Ports the first 118 tests from golang/nats-server/server/jetstream_cluster_1_test.go
to C# integration tests in JetStream/JetStreamCluster1Tests.cs. Adds the
Helpers/ scaffold (IntegrationTestBase, TestCluster, NatsTestClient, CheckHelper,
ConfigHelper) and Xunit.SkippableFact package; tests skip automatically unless
NATS_INTEGRATION_TESTS=true is set.
2026-03-01 12:14:55 -05:00
Joseph Doherty
a841b553f2
test(batch51): port 106 JetStream cluster 2 integration tests
2026-03-01 12:12:50 -05:00
Joseph Doherty
e846cb664a
test(batch48): add integration test harness infrastructure
...
Create 7 helper files under ZB.MOM.NatsNet.Server.IntegrationTests/Helpers/
and add Xunit.SkippableFact package. All tests skip gracefully via
IntegrationTestBase.CanBoot() guard until the .NET server runtime is complete.
2026-03-01 12:06:08 -05:00
Joseph Doherty
9690275287
Merge branch 'worktree-agent-adb1298d'
...
# Conflicts:
# dotnet/src/ZB.MOM.NatsNet.Server/Internal/Subscription.cs
2026-03-01 10:16:19 -05:00
Joseph Doherty
6a030151fc
feat(batch47): implement MQTT full runtime — JSA bridge, sessions, account manager, protocol handlers
...
- MqttJsa.cs: full JetStream API bridge (22 features, Sub-batch A 2269-2290)
- Async request/response helpers, consumer/stream CRUD, msg store/load/delete
- Send queue via Channel<MqttJsPubMsg>, ConcurrentDictionary reply tracking
- MqttAccountSessionManager.cs: per-account MQTT session manager (26 features, Sub-batch C 2292-2322)
- Session add/remove/lock/unlock, flapper tracking with cleanup timer
- Retained message in-memory cache with TTL eviction (ConcurrentDictionary)
- JSA reply dispatch, retained msg processing, session persist detection
- Subscription creation, retained message subject matching (SubscriptionIndex)
- createOrRestoreSession async (JetStream load + fallback to new session)
- processSubs builds NATS subscriptions with retained message delivery
- Stream migration stubs (transferUniqueSessStreamsToMuxed, transferRetained...)
- MqttTypes.cs: add Client and Seq to MqttSession; ExpiresFromCache to MqttRetainedMsg
- Remove stubs for MqttJsa and MqttAccountSessionManager
- MqttHelpers.cs: standalone helpers (Sub-batch F 2264-2268)
- IsMqttReservedSubscription, DecodeRetainedMessage, GeneratePubPerms,
CheckPubRetainedPerms, TopicFilterContainsWildcard, TopicToNatsSubject
- ClientConnection.Mqtt.cs: Mqtt property stub on ClientConnection (Sub-batch E entry)
- Subscription.cs: add internal Mqtt (MqttSub?) and InternalCallback fields
All 2660 unit tests pass, 0 failures.
2026-03-01 10:14:47 -05:00
Joseph Doherty
a321f96c6d
Merge branch 'worktree-agent-a4679340'
...
# Conflicts:
# dotnet/src/ZB.MOM.NatsNet.Server/Events/EventHelpers.cs
# dotnet/src/ZB.MOM.NatsNet.Server/Events/EventTypes.cs
# dotnet/src/ZB.MOM.NatsNet.Server/NatsServer.Events.cs
# dotnet/src/ZB.MOM.NatsNet.Server/NatsServerTypes.cs
# reports/current.md
2026-03-01 09:53:22 -05:00
Joseph Doherty
65c8e932e2
feat(batch45): implement events server methods — stats, remote tracking, connection events
...
Port 80 features from server/events.go including the full events infrastructure:
internal send/receive loops, system subscription machinery, statsz heartbeats,
remote server tracking, connection event advisories, user-info handler, OCSP peer
reject events, remote latency merge, kick/ldm client, and helper functions.
Add ClearConnectionHeartbeatTimer/SetConnectionHeartbeatTimer to Account,
add MsgHandler/SysMsgHandler delegates and supporting types (ServerApiResponse,
EventFilterOptions, StatszEventOptions, UserInfo, KickClientReq, LdmClientReq,
AccNumSubsReq) to EventTypes.cs, and add Seq field to ServerInfo for heartbeat
sequence tracking.
2026-03-01 09:41:20 -05:00
Joseph Doherty
01c47b1b35
fix: remove duplicate gateway types from MonitorTypes.cs
...
GatewayzOptions, Gatewayz, RemoteGatewayz, AccountGatewayz were defined
in both MonitorHelpers.cs (batch 42) and MonitorTypes.cs (batch 46).
Removed duplicates from MonitorTypes.cs, keeping the versions in
MonitorHelpers.cs.
2026-03-01 09:18:02 -05:00
Joseph Doherty
ab71f03b46
Merge branch 'worktree-agent-ad124859'
2026-03-01 09:16:26 -05:00
Joseph Doherty
743a89fecf
feat(batch46): implement monitor endpoints — varz, connz, routez, healthz, etc.
...
Adds NatsServer.Monitor.cs with all monitoring endpoint implementations
(Connz, Routez, Subsz, Gatewayz, Leafz, AccountStatz, Accountz, Varz,
Healthz, Raftz, Expvarz, Profilez, Stacksz, IPQueuesz, Root) and updates
Monitor/MonitorTypes.cs with the full set of monitoring response types.
2026-03-01 09:16:03 -05:00
Joseph Doherty
bad323a803
Merge branch 'worktree-agent-ae787158'
2026-03-01 09:01:43 -05:00
Joseph Doherty
dff3000461
feat(batch44): implement events core dispatch — Groups A-G from events.go
...
Port 46 deferred features from server/events.go covering the internal event
system foundation:
- Group A (EventHelpers.cs): NewPubMsg/pool, RouteStat, GetHash/GetHashSize,
GetAcceptEncoding, RemoteLatencySubjectForResponse, TotalSubs, AccForClient,
IssuerForClient, ClearTimer; CompressionType enum
- Group B (NatsServerTypes.cs): ServerInfo advisory fields (Seq, Time,
Capabilities, Tags, Metadata) + capability methods (SetJetStreamEnabled,
IsJetStreamEnabled, SetBinaryStreamSnapshot, IsBinaryStreamSnapshot,
SetAccountNrg, IsAccountNrg)
- Group C (ClientTypes.cs): ForAssignmentSnap, ForProposal, ForAdvisory on
ClientInfo
- Group D (EventTypes.cs): PubMsg.ReturnToPool; PubMsg.Client typed as
ClientConnection?; InternalState.Client typed as ClientConnection?;
InternalState.Seq changed to long field for Interlocked.Increment
- Group E (ClientConnection.Events.cs): SendInternalMsg delegates to server
- Group F (Account.Events.cs): AccountTrafficStats/Set + Account.Statz()
- Group G (NatsServer.Events.cs): InternalReceiveLoop, InternalSendLoop,
SendShutdownEvent, SendInternalAccountSysMsg, SendInternalMsgLocked,
SendInternalMsg, SendInternalMsgFromClient, SendInternalResponse,
EventsRunning, EventsEnabled, Node, InitEventTracking, FilterRequest,
NoInlineCallback*, SysSubscribe*, SystemSubscribe, SysUnsubscribe,
InboxReply, NewRespInbox, WrapChk; EventFilterOptions, ServerApiResponse,
ApiError types
- Subscription.SysMsgCb field added for system subscription dispatch
2026-03-01 09:01:03 -05:00
Joseph Doherty
be301e2e5a
Merge branch 'worktree-agent-a5ce7551'
2026-03-01 08:43:24 -05:00
Joseph Doherty
4e63820e7a
feat(batch42): implement foundation helpers — msgtrace, monitor helpers, scheduler
...
Group A: Create MsgTrace.cs with TraceCompressionType, MsgTraceState (factory
methods, pipeline event helpers, sendEvent/sendEventFromJetStream, trace header
injection) and MsgTraceHelper (sample, genHeaderMapIfTraceHeadersPresent,
initAndSendIngressErrEvent, isMsgTraceEnabled, msgTraceSupport). Adds Trace field
to PublishArgument and Trace accessor to ParseContext.
Group C: Create MonitorHelpers.cs with GatewayzOptions, Gatewayz, RemoteGatewayz,
AccountGatewayz, ExtImport, ExtServiceLatency types; plus 25 standalone helper
functions (newSubsDetailList, newSubsList, createProxyInfo, makePeerCerts,
decodeBool, decodeUint64, decodeInt, decodeState, decodeSubs, newSubDetail,
newClientSubDetail, myUptime, tlsCertNotAfter, urlsToStrings, getPinnedCertsAsSlice,
getMonitorGWOptions, createOutboundRemoteGatewayz, createOutboundAccountsGatewayz,
createAccountOutboundGatewayz, createInboundAccountsGatewayz,
createInboundAccountGatewayz, ResponseHandler, handleResponse, newExtServiceLatency,
newExtImport).
Group D: Implement GetScheduledMessages in MsgScheduling; add Seq field to InMsg
for out-of-band scheduling sort. Group B (GatewayInterestMode.String) already complete.
2026-03-01 08:42:50 -05:00
Joseph Doherty
96e395a113
feat(batch43): implement account resolvers and service latency tracking
...
Implements 37 deferred features from Batch 43:
Group A - Type methods:
- ServiceRespType.String: already existed via ToNatsString extension
- NewMapDest: already existed as MapDest.New factory
- ServiceLatency.merge → ServiceLatencyExtensions.Merge + Sanitize
Group B - Tracing headers (new TracingHeaders static class in AccountTypes.cs):
- newB3Header → TracingHeaders.NewB3Header
- newUberHeader → TracingHeaders.NewUberHeader
- newTraceCtxHeader → TracingHeaders.NewTraceCtxHeader
- shouldSample → TracingHeaders.ShouldSample
Group C - Service export timers (new extension methods in AccountTypes.cs):
- serviceImport.isRespServiceImport → ServiceImportEntryExtensions.IsRespServiceImport
- serviceExport.setResponseThresholdTimer → ServiceExportEntryExtensions.SetResponseThresholdTimer
- serviceExport.clearResponseThresholdTimer → ServiceExportEntryExtensions.ClearResponseThresholdTimer
- serviceExport.checkExpiredResponses → ServiceExportEntryExtensions.CheckExpiredResponses
Group D - Latency & client updates:
- sanitizeLatencyMetric → ServiceLatencyExtensions.SanitizeLatencyMetric
- updateAllClientsServiceExportResponseTime → ServiceExportClientHelpers.UpdateAllClientsServiceExportResponseTime
- ClientConnection.UpdateRrTrackingThreshold (helper for above)
Group E - Account resolvers (NatsServer.AccountResolvers.cs):
- authAccounts → NatsServer.AuthAccounts
- Server.SetAccountResolver + GetAccountResolver
- Server.UpdateAccountClaims + UpdateAccountClaimsWithRefresh
- buildPermissionsFromJwt → NatsServer.BuildPermissionsFromJwt (with JwtPermissions stub types)
- buildInternalNkeyUser → NatsServer.BuildInternalNkeyUser (with JwtUserClaims stub type)
- fetchAccount → NatsServer.FetchAccountFromResolverAsync
- respondToUpdate → NatsServer.RespondToUpdate (with ClaimUpdateResponse/Status/Error types)
- handleListRequest → NatsServer.HandleListRequest
- handleDeleteRequest → NatsServer.HandleDeleteRequest
- getOperatorKeys → NatsServer.GetOperatorKeys
- claimValidate → NatsServer.ClaimValidate
- removeCb → NatsServer.RemoveCb
Group F - Directory resolvers:
- Server.fetch → NatsServer.ServerFetch (stub falls back to direct resolver)
- DirAccResolver.Fetch, NewDirAccResolver, FetchTimeout already in AccountResolver.cs
- NewCacheDirAccResolver, CacheDirAccResolver.Reload already in AccountResolver.cs
Supporting changes:
- Account.cs: expose ExpiredTimeout as internal, add ReadLock/ReadUnlock/WriteLock/WriteUnlock
helpers plus GetResponseCount/GetResponseEntries for CheckExpiredResponses
- AccountTypes.cs: add using System.Globalization for hex parsing
- NatsServerTypes.cs: add AccountClaims.Name property (JWT name tag)
2026-03-01 08:32:40 -05:00
Joseph Doherty
037fb4bfc8
feat(batch35): merge js-cluster-remaining
2026-03-01 02:45:38 -05:00
Joseph Doherty
788abc1702
batch35: add and verify raft test waves T2-T4
2026-03-01 02:41:03 -05:00
Joseph Doherty
9e4405c2a1
batch35: add and verify test wave T1
2026-03-01 02:37:07 -05:00
Joseph Doherty
73d9871be6
feat(batch25): merge gateways
2026-03-01 02:31:54 -05:00
Joseph Doherty
8baa604dce
batch35: implement and verify feature group C
2026-03-01 02:30:35 -05:00
Joseph Doherty
35becf549a
batch35: implement and verify feature group B
2026-03-01 02:25:57 -05:00
Joseph Doherty
cf9f40ab0c
batch35: implement and verify feature group A
2026-03-01 02:21:30 -05:00
Joseph Doherty
a0763cd248
test(batch25): port gateway connect and tls baseline tests
2026-03-01 02:19:11 -05:00
Joseph Doherty
e9be0751ec
feat(batch25): implement gateway reply map and inbound message pipeline
2026-03-01 02:07:25 -05:00
Joseph Doherty
59fa600b3c
feat(batch25): implement gateway interest and outbound send logic
2026-03-01 02:00:08 -05:00
Joseph Doherty
e88f780033
test(batch29): add mapped raft node tests for batching behavior
2026-03-01 01:55:05 -05:00
Joseph Doherty
0fece7f2f3
feat(batch25): implement gateway URL and registry bookkeeping
2026-03-01 01:53:51 -05:00
Joseph Doherty
6ae023d4a7
feat(batch29): implement jetstream batching group-b validation and apply state
2026-03-01 01:51:17 -05:00
Joseph Doherty
1763304e28
feat(batch25): implement gateway handshake and gossip
2026-03-01 01:50:40 -05:00
Joseph Doherty
a83339fe71
feat(batch25): implement gateway bootstrap and solicitation
2026-03-01 01:47:07 -05:00
Joseph Doherty
02d3b610a1
feat(batch29): implement jetstream batching group-a lifecycle/store methods
2026-03-01 01:45:35 -05:00
Joseph Doherty
58db8adbc7
feat(batch39): merge consumer-dispatch
2026-03-01 01:35:20 -05:00
Joseph Doherty
8dcd582e8d
chore(batch24): remove generated build artifacts
2026-03-01 01:32:08 -05:00
Joseph Doherty
3e9ad16033
feat(batch24): complete leaf nodes implementation and verification
2026-03-01 01:31:57 -05:00
Joseph Doherty
09f73a0d2f
task6(batch39): implement shutdown and signal flow paths
2026-03-01 01:30:17 -05:00
Joseph Doherty
c0ec1f3341
task5(batch39): add reply parsing and consumer identity helpers
2026-03-01 01:25:26 -05:00
Joseph Doherty
519ee6ad49
task4(batch39): add delivery and redelivery dispatch behavior
2026-03-01 01:21:16 -05:00
Joseph Doherty
f537612d7c
task3(batch39): implement dispatch core and ack-floor processing
2026-03-01 01:16:27 -05:00
Joseph Doherty
b5d736ce89
feat(batch41): merge mqtt-client-io
2026-03-01 01:13:32 -05:00
Joseph Doherty
0760c550b4
task2(batch39): implement group A waiting/pull dispatch and T1 tests
2026-03-01 01:13:03 -05:00
Joseph Doherty
f2b1928a94
batch41: implement mqtt reader/writer and subject conversion slice
2026-03-01 01:08:31 -05:00
Joseph Doherty
2aaa38cad9
feat(batch38): merge consumer-lifecycle
2026-03-01 00:57:36 -05:00