Skip to content
This repository was archived by the owner on Oct 22, 2025. It is now read-only.

Conversation

@jog1t
Copy link
Collaborator

@jog1t jog1t commented Jul 28, 2025

Fixes KIT-185

TL;DR

Added support for pre-subscribing to events when establishing connections to actors, and implemented an onConnect handler for actors.

What changed?

  • Added an onConnect handler to the actor definition that gets called when a new connection is established
  • Implemented the ability to pre-subscribe to events when creating a connection
  • Added a new create() method on actor handles that returns a connection that must be manually connected
  • Added support for passing subscriptions in WebSocket and SSE connections
  • Updated the protocol to include subscriptions in headers and WebSocket protocols
  • Added debugging logs for event broadcasting

How to test?

  1. Use the new create() method to create a connection without immediately connecting:
const connection = client.counter.getOrCreate(["test-id"]).create();
connection.on("some-event", (data) => console.log(data));
connection.connect();
  1. Test the onConnect handler by creating an actor with the handler:
const myActor = actor({
  onConnect: (c, conn) => {
    c.broadcast("connected", "New connection established");
    conn.send("welcome", "Hello new connection!");
  },
  // other actor properties
});
  1. Pre-subscribe to events when connecting:
const connection = client.counter.getOrCreate(["test-id"]).create();
connection.on("onconnect:broadcast", (data) => console.log(data));
connection.on("onconnect:msg", (data) => console.log(data));
connection.connect();

Why make this change?

This change improves the developer experience by:

  1. Allowing actors to send initial data to clients when they connect
  2. Enabling clients to set up event listeners before the connection is established, ensuring no events are missed
  3. Reducing the need for multiple round-trips when setting up connections with subscriptions
  4. Providing more flexibility in how connections are established and managed

These improvements make it easier to build real-time applications with proper initialization sequences and event handling.

@claude
Copy link

claude bot commented Jul 28, 2025

Claude finished @jog1t's task —— View job


PR Review: feat: subscribe to events before connect

I'll review this pull request for code quality, potential bugs, performance, security, and test coverage.

Review Checklist:

  • Understand the feature by reading all changed files
  • Analyze code quality and best practices adherence
  • Check for potential bugs or issues
  • Evaluate performance considerations
  • Assess security concerns
  • Review test coverage
  • Provide comprehensive feedback

Feature Overview ✅

This PR implements the ability to subscribe to events before establishing a WebSocket connection. The key changes include:

  1. WebSocket Connection Enhancement: Adding support for passing subscriptions (subs) as a parameter during connection establishment
  2. Router Updates: Modified both actor and manager routers to handle subscription parameters
  3. Client-side Changes: Updated client drivers to send subscription information during connection
  4. Protocol Extensions: Enhanced connection protocols to support pre-connection subscriptions

This is a valuable optimization that eliminates the round-trip delay typically required for subscribing to events after connection establishment.


Code Quality Analysis ✅

Strengths:

  • Consistent Patterns: The implementation follows existing codebase patterns and conventions
  • Type Safety: Proper TypeScript types and Zod schemas are used throughout
  • Parameter Handling: Optional parameters are handled correctly across all connection types
  • Interface Consistency: Changes maintain API consistency across WebSocket, SSE, and HTTP connections

Code Structure:

The changes are well-distributed across the appropriate layers:

  • Protocol layer: Enhanced schemas in packages/core/src/manager/protocol/query.ts:67
  • Transport layer: Updated drivers and routers
  • Client layer: Modified connection establishment logic

Issues and Bugs Found 🔍

1. Hardcoded Subscription - packages/core/src/client/actor-conn.ts:262

subs: ["innit"],

Issue: This hardcodes a subscription to the "innit" event for all WebSocket connections.
Recommendation: Make this configurable or document why this specific event is always required.

2. Console.log Usage - packages/core/src/actor/instance.ts:885

console.log("subscribing to event", { eventName, connId: conn.id });

Issue: Direct console.log usage instead of the logging framework.
Recommendation: Replace with logger().debug("subscribing to event", { eventName, connId: conn.id });

3. Missing Parameter Validation

Issue: The subs parameter lacks explicit validation beyond basic type checking.
Recommendation: Add validation to ensure subscription event names follow expected patterns and don't conflict with internal events.

4. Subscription State Consistency

Issue: The connection could be established with subscriptions but fail to properly initialize them if the actor isn't ready.
Recommendation: Add explicit error handling for subscription initialization failures.


Security Assessment 🔒

Concerns:

  1. Event Name Validation: No explicit validation prevents subscription to potentially sensitive internal events
  2. Subscription Scope: No apparent restrictions on which events can be subscribed to during connection

Recommendations:

  • Add a whitelist or validation mechanism for subscribable events
  • Consider rate limiting subscription requests
  • Ensure subscription parameters are properly sanitized

Positive Aspects:

  • Maintains existing authentication and authorization patterns
  • Subscription data is passed through secure channels (headers/protocols)
  • No new attack vectors introduced beyond existing connection security

Performance Considerations ⚡

Improvements:

  • Reduced Latency: Eliminates post-connection subscription round-trips
  • Better UX: Events can be received immediately upon connection
  • Network Efficiency: Fewer messages required for connection setup

Minimal Impact:

  • Memory usage remains largely unchanged
  • No significant computational overhead added
  • Connection establishment overhead is minimal

Test Coverage Assessment 📋

Critical Gap: Missing Tests

The PR lacks explicit tests for the new subscription functionality. For a core feature affecting connection establishment, comprehensive testing is essential.

Recommended Test Coverage:

  1. Unit Tests: Test subscription parameter parsing and validation
  2. Integration Tests: Verify end-to-end subscription behavior
  3. Edge Cases: Test invalid subscription parameters, connection failures with subscriptions
  4. Backwards Compatibility: Ensure connections without subscriptions still work

Overall Assessment 📝

Strengths:

  • Valuable Feature: Addresses a real performance optimization need
  • Clean Implementation: Well-integrated with existing architecture
  • Type Safety: Proper TypeScript usage throughout
  • Consistent Patterns: Follows established codebase conventions

Areas for Improvement:

  • Missing Tests: Critical gap in test coverage
  • ⚠️ Minor Code Issues: Console.log usage and hardcoded subscriptions
  • ⚠️ Security Validation: Need for subscription parameter validation
  • ⚠️ Documentation: Could benefit from better inline documentation

Recommendation: Conditional Approval

This is a solid implementation of a useful feature, but requires addressing the test coverage gap and minor code issues before merging.


Action Items:

  1. High Priority: Add comprehensive test coverage for subscription functionality
  2. Medium Priority: Replace console.log with proper logging, remove hardcoded subscription
  3. Low Priority: Add subscription parameter validation and improve documentation

Copy link
Collaborator Author

jog1t commented Jul 28, 2025


How to use the Graphite Merge Queue

Add either label to this PR to merge it via the merge queue:

  • merge queue - adds this PR to the back of the merge queue
  • hotfix - for urgent hot fixes, skip the queue and merge this PR next

You must have a Graphite account in order to use the merge queue. Sign up using this link.

An organization admin has enabled the Graphite Merge Queue in this repository.

Please do not merge from GitHub as this will restart CI on PRs being processed by the merge queue.

This stack of pull requests is managed by Graphite. Learn more about stacking.

@pkg-pr-new
Copy link

pkg-pr-new bot commented Jul 28, 2025

More templates

@rivetkit/actor

pnpm add https://pkg.pr.new/rivet-gg/rivetkit/@rivetkit/actor@1146

@rivetkit/core

pnpm add https://pkg.pr.new/rivet-gg/rivetkit/@rivetkit/core@1146

@rivetkit/db

pnpm add https://pkg.pr.new/rivet-gg/rivetkit/@rivetkit/db@1146

rivetkit

pnpm add https://pkg.pr.new/rivet-gg/rivetkit@1146

@rivetkit/cloudflare-workers

pnpm add https://pkg.pr.new/rivet-gg/rivetkit/@rivetkit/cloudflare-workers@1146

@rivetkit/redis

pnpm add https://pkg.pr.new/rivet-gg/rivetkit/@rivetkit/redis@1146

@rivetkit/framework-base

pnpm add https://pkg.pr.new/rivet-gg/rivetkit/@rivetkit/framework-base@1146

@rivetkit/next-js

pnpm add https://pkg.pr.new/rivet-gg/rivetkit/@rivetkit/next-js@1146

@rivetkit/react

pnpm add https://pkg.pr.new/rivet-gg/rivetkit/@rivetkit/react@1146

commit: 6432ea3

Base automatically changed from 07-28-fix_react_memoize_event_listener to main August 4, 2025 20:48
@jog1t jog1t force-pushed the 07-29-feat_subscribe_to_events_before_connect branch from b1877a0 to cad2b5d Compare August 5, 2025 22:47
@claude
Copy link

claude bot commented Aug 5, 2025

Claude finished @jog1t's task —— View job


PR Review: feat: subscribe to events before connect

Review Checklist:

  • Read and understand the feature implementation across all changed files
  • Analyze code quality and adherence to best practices
  • Identify potential bugs and issues
  • Evaluate performance considerations
  • Assess security concerns
  • Review test coverage
  • Provide comprehensive feedback and recommendations

Feature Overview ✅

This PR implements the ability to subscribe to events before establishing a WebSocket connection. The key changes include:

  1. Protocol Enhancement: Added subs parameter to ConnectWebSocketRequestSchema in packages/core/src/manager/protocol/query.ts:67
  2. Manager Router Updates: Enhanced WebSocket protocol parsing to handle subscriptions in packages/core/src/manager/router.ts:90-94
  3. Actor Router Integration: Modified connection establishment to process pre-connection subscriptions
  4. Client-side Implementation: Updated drivers to send subscription information during connection
  5. Subscription Processing: Enhanced actor instance to handle subscriptions during connection creation

This is a valuable optimization that eliminates the round-trip delay typically required for subscribing to events after connection establishment.


Code Quality Analysis ✅

Strengths:

  • Consistent Implementation: The feature follows existing codebase patterns and conventions
  • Type Safety: Proper TypeScript types and Zod schemas are used throughout
  • Error Handling: Appropriate error handling for invalid subscription JSON parsing
  • Backwards Compatibility: The subs parameter is optional, maintaining compatibility

Architecture:

  • Clean Separation: Changes are properly distributed across protocol, transport, and client layers
  • Interface Consistency: Maintains API consistency across WebSocket, SSE, and HTTP connections

Issues and Bugs Found 🔍

1. Hardcoded Subscription - packages/core/src/client/actor-conn.ts:262

subs: ["innit"],

Issue: This hardcodes a subscription to the "innit" event for all WebSocket connections.
Impact: Every connection will automatically subscribe to this event regardless of intent.
Recommendation: Make this configurable or document why this specific event is always required.

2. Console.log Usage - packages/core/src/actor/instance.ts:885

console.log("subscribing to event", { eventName, connId: conn.id });

Issue: Direct console.log usage instead of the project's logging framework.
Recommendation: Replace with logger().debug("subscribing to event", { eventName, connId: conn.id }); per project guidelines.

3. Additional Console.log - packages/core/src/actor/instance.ts:1262

console.log("broadcasting event", {

Issue: Another console.log instead of proper logging.
Recommendation: Replace with logger().debug().

4. Missing Subscription Validation

Issue: No validation of subscription event names beyond basic JSON parsing.
Recommendation: Add validation to prevent subscription to internal/system events that shouldn't be accessible to clients.


Security Assessment 🔒

Low Risk Issues:

  1. Event Name Validation: Currently no restrictions on which events can be subscribed to during connection
  2. Subscription Scope: No apparent filtering or access control for subscription requests

Recommendations:

  • Consider adding an event whitelist or validation mechanism
  • Ensure internal events (like system events) cannot be subscribed to by clients
  • Add basic rate limiting considerations for subscription requests

Positive Aspects:

  • ✅ Maintains existing authentication and authorization patterns
  • ✅ Subscription data passed through secure channels
  • ✅ No new attack vectors beyond existing connection security

Performance Considerations ⚡

Improvements:

  • Reduced Latency: Eliminates post-connection subscription round-trips
  • Better UX: Events can be received immediately upon connection
  • Network Efficiency: Fewer messages required for connection setup

Impact Assessment:

  • Memory: Minimal impact - subscription tracking already exists
  • CPU: No significant computational overhead
  • Network: Reduces overall message count for typical connection patterns

Test Coverage Assessment 📋

Critical Gap: Missing Tests

The PR lacks explicit tests for the new subscription functionality. This is concerning for a core feature affecting connection establishment.

Required Test Coverage:

  1. Unit Tests:

    • Subscription parameter parsing and validation
    • WebSocket protocol parsing with subscription data
    • Connection creation with pre-subscriptions
  2. Integration Tests:

    • End-to-end subscription behavior
    • Event delivery to pre-subscribed connections
    • Mixed scenarios (some with subs, some without)
  3. Edge Cases:

    • Invalid subscription JSON
    • Empty subscription arrays
    • Connection failures with subscriptions
    • Backwards compatibility (connections without subscriptions)

Overall Assessment 📝

Strengths:

  • Valuable Feature: Addresses real performance optimization need
  • Clean Implementation: Well-integrated with existing architecture
  • Type Safety: Proper TypeScript usage throughout
  • Backwards Compatible: Optional parameters maintain compatibility

Issues Requiring Attention:

  • Missing Tests: Critical gap in test coverage for core functionality
  • Code Quality: Console.log usage and hardcoded subscriptions
  • ⚠️ Validation: Missing subscription parameter validation
  • ⚠️ Documentation: Limited inline documentation for new behavior

Recommendation: Approve with Conditions

This is a well-implemented feature that provides clear value, but requires addressing the following before merge:

High Priority:

  1. Add comprehensive test coverage for subscription functionality
  2. Replace console.log statements with proper logging
  3. Remove or make configurable the hardcoded "innit" subscription

Medium Priority:
4. Add validation for subscription event names
5. Improve inline documentation


Files needing attention:

  • packages/core/src/client/actor-conn.ts:262 - Remove hardcoded subscription
  • packages/core/src/actor/instance.ts:885,1262 - Replace console.log with logger()
  • Missing: Test files for new functionality

@jog1t jog1t force-pushed the 07-29-feat_subscribe_to_events_before_connect branch from cad2b5d to 6432ea3 Compare August 6, 2025 01:26
@claude
Copy link

claude bot commented Aug 6, 2025

Claude finished @jog1t's task —— View job


PR Review: feat: subscribe to events before connect

Review Checklist:

  • Read and understand all changed files
  • Analyze code quality and adherence to best practices
  • Identify potential bugs and issues
  • Evaluate performance considerations
  • Assess security concerns
  • Review test coverage
  • Provide comprehensive feedback and recommendations

Feature Overview ✅

This PR implements the ability to subscribe to events before establishing a WebSocket connection. The key changes include:

  1. Protocol Enhancement: Added subscriptions parameter to connection schemas in packages/core/src/manager/protocol/query.ts:73-86
  2. Manager Router Updates: Enhanced WebSocket protocol parsing to handle subscriptions in packages/core/src/manager/router.ts:95-99
  3. Actor Router Integration: Modified connection establishment to process pre-connection subscriptions in packages/core/src/actor/router.ts:97-99
  4. Client-side Implementation: Updated drivers to send subscription information during connection
  5. Subscription Processing: Enhanced actor instance to handle subscriptions during connection creation

This is a valuable optimization that eliminates the round-trip delay typically required for subscribing to events after connection establishment.


Code Quality Analysis ✅

Strengths:

  • Consistent Implementation: The feature follows existing codebase patterns and conventions
  • Type Safety: Proper TypeScript types and Zod schemas are used throughout
  • Error Handling: Appropriate error handling for invalid subscription JSON parsing
  • Backwards Compatibility: The subscriptions parameter is optional, maintaining compatibility

Architecture:

  • Clean Separation: Changes are properly distributed across protocol, transport, and client layers
  • Interface Consistency: Maintains API consistency across WebSocket, SSE, and HTTP connections

Issues and Bugs Found 🔍

1. Hardcoded Subscription - packages/core/src/client/actor-conn.ts:259

Array.from(this.#eventSubscriptions.keys()),

Issue: The subscription list is built from existing subscriptions, but there's hardcoded subscription logic elsewhere.
Location: Line 259 passes existing subscription keys, but this should include pre-connection subscriptions.

2. Console.log Usage - packages/core/src/actor/instance.ts:885,1262

console.log("subscribing to event", { eventName, connId: conn.id });
console.log("broadcasting event", {

Issue: Direct console.log usage instead of the project's logging framework.
Recommendation: Replace with logger().debug() per project guidelines.

3. Missing Subscription Validation

Issue: No validation of subscription event names beyond basic JSON parsing in protocol handling.
Recommendation: Add validation to prevent subscription to internal/system events that shouldn't be accessible to clients.

4. Protocol Parameter Naming Inconsistency

Issue: The parameter is called subscriptions in the WebSocket schema but subs in protocol parsing.
Location: packages/core/src/manager/router.ts:95 uses subs. prefix vs subscriptions in schema.


Security Assessment 🔒

Low Risk Issues:

  1. Event Name Validation: Currently no restrictions on which events can be subscribed to during connection
  2. Subscription Scope: No apparent filtering or access control for subscription requests

Recommendations:

  • Consider adding an event whitelist or validation mechanism for subscribable events
  • Ensure internal events (like system events) cannot be subscribed to by clients
  • Add basic rate limiting considerations for subscription requests

Positive Aspects:

  • ✅ Maintains existing authentication and authorization patterns
  • ✅ Subscription data passed through secure channels (headers/protocols)
  • ✅ No new attack vectors beyond existing connection security

Performance Considerations ⚡

Improvements:

  • Reduced Latency: Eliminates post-connection subscription round-trips
  • Better UX: Events can be received immediately upon connection
  • Network Efficiency: Fewer messages required for connection setup

Impact Assessment:

  • Memory: Minimal impact - subscription tracking already exists
  • CPU: No significant computational overhead
  • Network: Reduces overall message count for typical connection patterns

Test Coverage Assessment 📋

Positive: Existing Test Updates

The PR includes updates to test files:

  • packages/core/src/driver-test-suite/tests/actor-conn.ts shows comprehensive connection tests
  • Tests cover various connection methods and event handling scenarios

Area for Improvement: Pre-Connection Subscription Tests

While existing tests cover connections and events, I don't see specific tests for:

  1. Pre-connection subscription behavior: Verifying events are received immediately upon connection
  2. Subscription parameter validation: Testing invalid subscription JSON or event names
  3. Mixed subscription scenarios: Pre-connection + post-connection subscriptions

Recommended Additional Tests:

test("should receive events from pre-connection subscriptions", async (c) => {
  const { client } = await setupDriverTest(c, driverTestConfig);
  
  // Set up pre-connection subscription and connect
  const connection = client.counter.getOrCreate(["test-pre-sub"]).create();
  connection.on("newCount", (count) => { /* handler */ });
  connection.connect();
  
  // Verify immediate event delivery after connection
  await connection.increment(5);
  // Assert event was received
});

Overall Assessment 📝

Strengths:

  • Valuable Feature: Addresses real performance optimization need
  • Clean Implementation: Well-integrated with existing architecture
  • Type Safety: Proper TypeScript usage throughout
  • Backwards Compatible: Optional parameters maintain compatibility
  • Test Coverage: Good baseline test coverage exists

Issues Requiring Attention:

High Priority:

  1. Replace console.log statements with proper logging (packages/core/src/actor/instance.ts:885,1262)
  2. Resolve protocol parameter naming inconsistency (subs vs subscriptions)

Medium Priority:
3. Add validation for subscription event names to prevent access to internal events
4. Add specific tests for pre-connection subscription functionality

Low Priority:
5. Improve inline documentation for new subscription behavior


Recommendation: Approve with Minor Changes

This is a well-implemented feature that provides clear value. The issues identified are minor and can be addressed in follow-up work if needed. The core functionality is sound and follows project patterns well.

Files needing attention:

  • packages/core/src/actor/instance.ts:885,1262 - Replace console.log with logger()
  • Consider adding subscription parameter validation
  • Optional: Add more specific tests for pre-connection subscription scenarios

@jog1t jog1t changed the title feat: subscribe to events before connect feat(core): subscribe to events before connect Aug 6, 2025
@jog1t jog1t marked this pull request as ready for review August 6, 2025 01:27
@jog1t jog1t self-assigned this Aug 6, 2025
@jog1t jog1t requested a review from NathanFlurry August 6, 2025 01:28
@jog1t jog1t force-pushed the 07-29-feat_subscribe_to_events_before_connect branch from 6432ea3 to 0127964 Compare September 17, 2025 16:45
@vercel
Copy link

vercel bot commented Sep 17, 2025

The latest updates on your projects. Learn more about Vercel for GitHub.

Project Deployment Preview Comments Updated (UTC)
rivetkit-express Error Error Sep 17, 2025 5:03pm

@jog1t jog1t force-pushed the 07-29-feat_subscribe_to_events_before_connect branch from 0127964 to d98968e Compare September 17, 2025 17:02
@claude
Copy link

claude bot commented Sep 17, 2025

Claude finished @jog1t's task —— View job


PR Review: feat(core): subscribe to events before connect

Review Checklist:

  • Read and understand all changed files
  • Analyze code quality and adherence to best practices
  • Identify potential bugs and issues
  • Evaluate performance considerations
  • Assess security concerns
  • Review test coverage
  • Provide comprehensive feedback and recommendations

Feature Overview ✅

This PR implements the ability to subscribe to events before establishing a WebSocket connection, plus an onConnect handler for actors. Key changes include:

  1. Protocol Enhancement: Added subscriptions parameter to connection schemas (packages/rivetkit/src/manager/protocol/query.ts:74-87)
  2. Actor Handle API: New create() method that returns ActorManualConn requiring manual connection (packages/rivetkit/src/client/actor-handle.ts:175-192)
  3. Connection Logic: Enhanced WebSocket connection to pass subscription list during handshake (packages/rivetkit/src/client/actor-conn.ts:281)
  4. Actor Lifecycle: Added onConnect handler support with broadcast and direct messaging capabilities
  5. Pre-subscription Processing: Subscriptions are processed during connection creation in actor instance

This is a valuable optimization that eliminates the round-trip delay for event subscriptions after connection establishment.


Code Quality Analysis ✅

Strengths:

  • Consistent Implementation: Follows existing codebase patterns and conventions
  • Type Safety: Proper TypeScript types and Zod schemas throughout
  • Backwards Compatibility: The subscriptions parameter is optional, maintaining compatibility
  • Clean API Design: The new create() method provides clear distinction from connect()

Architecture:

  • Clean Separation: Changes properly distributed across protocol, transport, and client layers
  • Interface Consistency: Maintains API consistency across WebSocket, SSE, and HTTP connections

Issues and Bugs Found 🔍

1. Console.log Usage - packages/rivetkit/src/actor/instance.ts:1026,1499

console.log("subscribing to event", { eventName, connId: conn.id });
console.log("broadcasting event", {

Issue: Direct console.log usage instead of the project's logging framework.
Recommendation: Replace with logger().debug() per CLAUDE.md guidelines.

2. Missing Subscription Validation

Issue: No validation of subscription event names beyond basic JSON parsing in protocol handling.
Recommendation: Add validation to prevent subscription to internal/system events that shouldn't be accessible to clients.

3. Potential Race Condition

Issue: In packages/rivetkit/src/actor/instance.ts:954-958, subscriptions are processed after connection creation but before onConnect handler.
Recommendation: Consider if this ordering could cause missed events from the onConnect handler.


Performance Considerations ⚡

Improvements:

  • Reduced Latency: Eliminates post-connection subscription round-trips
  • Better UX: Events can be received immediately upon connection
  • Network Efficiency: Fewer messages required for connection setup

Impact Assessment:

  • Memory: Minimal impact - subscription tracking already exists
  • CPU: No significant computational overhead
  • Network: Reduces overall message count for typical connection patterns

Potential Concerns:

  • Connection Setup Time: Slightly increased due to subscription parsing, but offset by eliminated round-trips
  • WebSocket Payload: Subscription data adds to initial connection payload

Security Assessment 🔒

Low Risk Issues:

  1. Event Name Validation: Currently no restrictions on which events can be subscribed to during connection
  2. Subscription Scope: No apparent filtering or access control for subscription requests

Recommendations:

  • Consider adding an event whitelist or validation mechanism for subscribable events
  • Ensure internal events (like system events) cannot be subscribed to by clients
  • Add basic rate limiting considerations for subscription requests

Positive Aspects:

  • ✅ Maintains existing authentication and authorization patterns
  • ✅ Subscription data passed through secure channels (headers/protocols)
  • ✅ No new attack vectors beyond existing connection security
  • ✅ JSON parsing includes proper error handling

Test Coverage Assessment 📋

Positive: Good Baseline Coverage

The PR includes updates to test files:

  • packages/rivetkit/src/driver-test-suite/tests/actor-conn.ts shows comprehensive connection tests
  • Tests cover various connection methods and event handling scenarios
  • Test fixture updated to demonstrate onConnect functionality

Area for Improvement: Pre-Connection Subscription Tests

While existing tests cover connections and events, specific tests for pre-connection subscription behavior would strengthen coverage:

  1. Pre-connection subscription behavior: Verifying events are received immediately upon connection
  2. Subscription parameter validation: Testing invalid subscription JSON or event names
  3. Mixed subscription scenarios: Pre-connection + post-connection subscriptions
  4. onConnect handler integration: Testing that pre-subscribed clients receive onConnect events

Test Quality:

  • Existing Tests Updated: Good integration with existing test suite
  • Real-world Usage: Test fixture demonstrates practical usage patterns
  • ⚠️ Missing Edge Cases: Could benefit from more specific pre-subscription test scenarios

Overall Assessment 📝

Strengths:

  • Valuable Feature: Addresses real performance optimization need
  • Clean Implementation: Well-integrated with existing architecture
  • Type Safety: Proper TypeScript usage throughout
  • Backwards Compatible: Optional parameters maintain compatibility
  • Good Test Integration: Updates existing test suite appropriately

Issues Requiring Attention:

High Priority:

  1. Replace console.log statements with proper logging (packages/rivetkit/src/actor/instance.ts:1026,1499)

Medium Priority:
2. Add validation for subscription event names to prevent access to internal events
3. Consider subscription processing order relative to onConnect handler

Low Priority:
4. Add more specific tests for pre-connection subscription functionality
5. Improve inline documentation for new subscription behavior


Recommendation: Approve with Minor Changes

This is a well-implemented feature that provides clear value. The issues identified are minor and can be addressed in follow-up work if needed. The core functionality is sound and follows project patterns well.

Files needing attention:

  • packages/rivetkit/src/actor/instance.ts:1026,1499 - Replace console.log with logger()
  • Consider adding subscription parameter validation
  • Optional: Add more specific tests for pre-connection subscription scenarios

The implementation successfully delivers the intended functionality while maintaining code quality and backwards compatibility.


Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant