Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(funding): Add defaultFunding8hrPpm field to Perpetual Create/Update indexer events #2674

Open
wants to merge 4 commits into
base: main
Choose a base branch
from

Conversation

teddyding
Copy link
Contributor

@teddyding teddyding commented Jan 7, 2025

CT-1340

Changelist

  • Database migration to add DefaultFundingRate1H
  • In PerpetualMarketCreateEvent and UpdatePerpetualEvent, add DefaultFunding8hrPpm. In handlers, convert these ppm into 1hr funding rate and store in DB.

Test Plan

[Describe how this PR was tested (if applicable)]

Author/Reviewer Checklist

  • If this PR has changes that result in a different app state given the same prior state and transaction list, manually add the state-breaking label.
  • If the PR has breaking postgres changes to the indexer add the indexer-postgres-breaking label.
  • If this PR isn't state-breaking but has changes that modify behavior in PrepareProposal or ProcessProposal, manually add the label proposal-breaking.
  • If this PR is one of many that implement a specific feature, manually label them all feature:[feature-name].
  • If you wish to for mergify-bot to automatically create a PR to backport your change to a release branch, manually add the label backport/[branch-name].
  • Manually add any of the following labels: refactor, chore, bug.

Summary by CodeRabbit

Release Notes: Perpetual Market Funding Rate Enhancement

New Features

  • Added a new defaultFundingRate1H property to perpetual market data structures.
  • Introduced version 3 of Perpetual Market and Update Perpetual events with enhanced funding rate information.
  • Expanded event and database schemas to support 1-hour and 8-hour funding rate calculations.

Changes

  • Updated multiple system components to support new funding rate parameters.
  • Modified event handling and validation processes across indexer and protocol services.
  • Extended API documentation and response objects to include new funding rate fields.
  • Enhanced test coverage to validate new event structures and parameters.

Compatibility

  • Previous event versions (V1 and V2) are now deprecated.
  • New event versions (V3) include additional DefaultFunding8HrPpm parameter.

Impact

  • Provides more granular funding rate tracking for perpetual markets.
  • Enables more precise funding rate calculations and reporting.

Copy link
Contributor

coderabbitai bot commented Jan 7, 2025

Walkthrough

This pull request introduces a comprehensive update to the system's handling of perpetual market funding rates. The changes span multiple packages and services, adding a new defaultFundingRate1H property to various data models, interfaces, and event structures. The primary focus is on enhancing the representation and processing of one-hour default funding rates across the indexer, protocol, and services layers. The modifications include database migrations, type definitions, event handling, and test suite updates to support this new funding rate parameter.

Changes

File/Path Change Summary
indexer/packages/postgres/README.md Added note about potential test failures related to migrations
indexer/packages/postgres/__tests__/db/migrations.test.ts Renamed test case descriptions and marked some tests as skipped
indexer/packages/postgres/__tests__/helpers/constants.ts Added defaultFundingRate1H to perpetual market instances
indexer/packages/postgres/src/db/migrations/migration_files/20250107145033_default_1hr_funding_for_perp.ts Added migration for defaultFundingRate1H column in perpetual_markets table
indexer/packages/postgres/src/models/perpetual-market-model.ts Added defaultFundingRate1H to model and schema
indexer/packages/postgres/src/types/db-model-types.ts Added optional defaultFundingRate1H property to PerpetualMarketFromDatabase interface
indexer/packages/postgres/src/types/perpetual-market-types.ts Added defaultFundingRate1H to PerpetualMarketCreateObject interface
indexer/packages/postgres/src/types/websocket-message-types.ts Added optional defaultFundingRate1H to TradingPerpetualMarketMessage interface
indexer/packages/v4-protos/src/codegen/dydxprotocol/indexer/events/events.ts Introduced new event versions with funding rate parameter
indexer/services/comlink/public/api-documentation.md Updated API documentation to include new funding rate field
indexer/services/comlink/public/swagger.json Added defaultFundingRate1H to PerpetualMarketResponseObject schema
indexer/services/comlink/src/request-helpers/request-transformer.ts Updated return object to include defaultFundingRate1H
indexer/services/ender/__tests__/handlers/perpetual-market-handler.test.ts Added tests for PerpetualMarketCreateEventV3
indexer/services/ender/src/handlers/perpetual-market-handler.ts Updated handler to support PerpetualMarketCreateEventV3
protocol/indexer/events/constants.go Updated event version constants
protocol/x/clob/keeper/perpetual_test.go Updated expected event types to UpdatePerpetualEventV3

Sequence Diagram

sequenceDiagram
    participant Client
    participant IndexerService
    participant DatabaseLayer
    participant EventProcessor

    Client->>IndexerService: Request Perpetual Market Data
    IndexerService->>DatabaseLayer: Fetch Market with defaultFundingRate1H
    DatabaseLayer-->>IndexerService: Return Market Data
    IndexerService->>EventProcessor: Process Market Creation Event
    EventProcessor->>EventProcessor: Calculate Funding Rate
    EventProcessor-->>IndexerService: Emit Updated Market Event
    IndexerService-->>Client: Return Market Information
Loading

Possibly related PRs

Suggested Labels

performance

Suggested Reviewers

  • roy-dydx

Poem

🐰 Funding rates hop and dance,
A new parameter takes its stance,
One hour's rhythm, precise and clear,
Indexer's logic now without fear!
Code hops forward, rates aligned 🌟


Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR. (Beta)
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

@teddyding teddyding changed the title feat(funding): Add defaultFunding8hrPpm field to perpetual indexer events feat(funding): Add defaultFunding8hrPpm field to perpetual create and update indexer events Jan 7, 2025
@teddyding teddyding changed the title feat(funding): Add defaultFunding8hrPpm field to perpetual create and update indexer events feat(funding): Add defaultFunding8hrPpm field to Perpetual Create/Update indexer events Jan 7, 2025
@teddyding teddyding changed the title feat(funding): Add defaultFunding8hrPpm field to Perpetual Create/Update indexer events feat(funding): [CT-1340] Add defaultFunding8hrPpm field to Perpetual Create/Update indexer events Jan 7, 2025
Copy link

linear bot commented Jan 7, 2025

@teddyding teddyding changed the title feat(funding): [CT-1340] Add defaultFunding8hrPpm field to Perpetual Create/Update indexer events feat(funding) Add defaultFunding8hrPpm field to Perpetual Create/Update indexer events Jan 7, 2025
@teddyding teddyding force-pushed the td/default-funding-indexer branch 2 times, most recently from f2754f1 to a5349cd Compare January 9, 2025 17:37
@teddyding teddyding force-pushed the td/default-funding-indexer branch from a5349cd to 84dc866 Compare January 14, 2025 17:37
@teddyding teddyding changed the title feat(funding) Add defaultFunding8hrPpm field to Perpetual Create/Update indexer events feat(funding): Add defaultFunding8hrPpm field to Perpetual Create/Update indexer events Jan 14, 2025
@teddyding teddyding marked this pull request as ready for review January 14, 2025 18:27
@teddyding teddyding requested a review from a team as a code owner January 14, 2025 18:27
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 7

🔭 Outside diff range comments (1)
indexer/services/ender/src/validators/update-perpetual-validator.ts (1)

Line range hint 25-31: Fix type inconsistency in createHandlers method.

The method's return type Handler<UpdatePerpetualEventV1>[] doesn't match the class's type parameter which includes V2 and V3 events. This could lead to type errors when handling newer event versions.

-  ): Handler<UpdatePerpetualEventV1>[] {
-    const handler: Handler<UpdatePerpetualEventV1> = new UpdatePerpetualHandler(
+  ): Handler<UpdatePerpetualEventV1 | UpdatePerpetualEventV2 | UpdatePerpetualEventV3>[] {
+    const handler: Handler<UpdatePerpetualEventV1 | UpdatePerpetualEventV2 | UpdatePerpetualEventV3> = new UpdatePerpetualHandler(
🧹 Nitpick comments (10)
protocol/indexer/events/perpetual.go (1)

8-8: Update function documentation to include the new parameter.

The documentation comment should describe the defaultFundingPpm parameter and its purpose.

-// NewUpdatePerpetualEvent creates a UpdatePerpetualEventV3 representing
-// update of a perpetual.
+// NewUpdatePerpetualEvent creates a UpdatePerpetualEventV3 representing
+// update of a perpetual.
+//
+// Parameters:
+//   - defaultFundingPpm: The default 8-hour funding rate in parts per million
protocol/indexer/events/perpetual_test.go (1)

20-20: Add test cases for edge values of defaultFundingPpm.

Consider adding test cases for:

  • Maximum allowed funding rate
  • Minimum (negative) funding rate
  • Zero funding rate
protocol/indexer/events/perpetual_market_create_test.go (2)

26-26: Document the significance of the default funding value.

The test uses a value of 100 for defaultFundingPpm. Consider adding a comment explaining why this specific value was chosen and what it represents in the context of funding rates.


Line range hint 28-41: Consider adding more test cases for the funding rate field.

While the happy path is tested, consider adding test cases for:

  • Edge cases (e.g., maximum/minimum allowed values)
  • Negative values
  • Zero value
indexer/services/ender/__tests__/handlers/update-perpetual-handler.test.ts (1)

17-17: LGTM! Handler tests properly extended for V3 events.

The test suite is correctly updated to include the new V3 event type, maintaining consistency with existing test patterns.

Consider adding specific test assertions for the new defaultFundingRate1H field in the perpetualMarket object expectations, similar to how market type is conditionally checked:

 expect(perpetualMarket).toEqual(expect.objectContaining({
   id: event.id.toString(),
   ticker: event.ticker,
   marketId: event.marketId,
   atomicResolution: event.atomicResolution,
   liquidityTierId: event.liquidityTier,
   // Add V2-specific field expectations when testing V2 events
   ...('marketType' in event && {
     marketType: eventPerpetualMarketTypeToIndexerPerpetualMarketType(event.marketType),
   }),
+  // Add V3-specific field expectations when testing V3 events
+  ...('defaultFunding8hrPpm' in event && {
+    defaultFundingRate1H: event.defaultFunding8hrPpm,
+  }),
 }));

Also applies to: 25-25, 76-80, 84-85

indexer/services/comlink/src/types.ts (1)

355-355: LGTM: Optional defaultFundingRate1H field added to interface

The addition of the optional defaultFundingRate1H field to the PerpetualMarketResponseObject interface is well-structured. Consider adding JSDoc comments to document the field's purpose and format.

Add JSDoc comments to describe the field:

+  /**
+   * The default 1-hour funding rate for the perpetual market.
+   * Represented as a string decimal, e.g., "0.0001" for 0.01% per hour.
+   */
   defaultFundingRate1H?: string,
indexer/packages/v4-protos/src/codegen/dydxprotocol/indexer/events/events.ts (1)

1111-1186: New V3 interfaces look good, but could use more detailed documentation.

The new interfaces properly extend their V2 counterparts with the defaultFunding8hrPpm field. Consider adding more detailed documentation for the new field:

  • Valid range of values
  • Impact on funding rate calculations
  • Example values and their real-world interpretations

Also applies to: 1583-1627

indexer/packages/postgres/README.md (1)

10-11: Improve clarity of migration testing guidance

The added note about test failures is helpful but could be clearer. Consider rewording to:
"Note: Test cases in __tests__/db/migrations.test.ts may fail when a model is modified by a new migration. In such cases, comment out the affected test cases until the model changes are finalized."

🧰 Tools
🪛 LanguageTool

[style] ~11-~11: Consider a shorter alternative to avoid wordiness.
Context: ... modified due to the latest migration. In order to migrate in dev and staging, you must re...

(IN_ORDER_TO_PREMIUM)

indexer/services/ender/package.json (1)

10-10: Consider improving build:watch script robustness

The build:watch script could be made more robust by:

  1. Using a cross-platform rimraf instead of rm -rf for better Windows compatibility
  2. Handling the cp command failure gracefully
  3. Consider using a package.json script for the cleanup steps

Example:

{
  "scripts": {
    "clean": "rimraf build/",
    "copy-scripts": "cp -r src/scripts build/src/scripts",
    "build:watch": "pnpm run clean && (tsc --watch & pnpm run copy-scripts)"
  }
}
indexer/services/comlink/public/swagger.json (1)

1141-1143: Consider adding validation constraints for the rate field.

The defaultFundingRate1H field is defined as a string without any validation constraints. Consider adding:

  1. Pattern constraint to ensure valid numeric string format
  2. Description field to document the expected format and valid range
   "defaultFundingRate1H": {
-    "type": "string"
+    "type": "string",
+    "pattern": "^-?\\d*\\.?\\d+$",
+    "description": "Default 1-hour funding rate as a decimal string (e.g., '0.0001' for 0.01%)"
   }
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 949b46c and a2cf22c.

⛔ Files ignored due to path filters (2)
  • protocol/indexer/events/events.pb.go is excluded by !**/*.pb.go
  • protocol/x/perpetuals/types/perpetual.pb.go is excluded by !**/*.pb.go
📒 Files selected for processing (61)
  • indexer/packages/postgres/README.md (1 hunks)
  • indexer/packages/postgres/__tests__/db/migrations.test.ts (1 hunks)
  • indexer/packages/postgres/__tests__/helpers/constants.ts (5 hunks)
  • indexer/packages/postgres/src/db/migrations/migration_files/20250107145033_default_1hr_funding_for_perp.ts (1 hunks)
  • indexer/packages/postgres/src/models/perpetual-market-model.ts (3 hunks)
  • indexer/packages/postgres/src/types/db-model-types.ts (1 hunks)
  • indexer/packages/postgres/src/types/perpetual-market-types.ts (2 hunks)
  • indexer/packages/postgres/src/types/websocket-message-types.ts (1 hunks)
  • indexer/packages/v4-protos/src/codegen/dydxprotocol/indexer/events/events.ts (8 hunks)
  • indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/perpetual.ts (2 hunks)
  • indexer/services/comlink/__tests__/lib/request-helpers/request-transformer.test.ts (1 hunks)
  • indexer/services/comlink/public/api-documentation.md (6 hunks)
  • indexer/services/comlink/public/swagger.json (1 hunks)
  • indexer/services/comlink/src/request-helpers/request-transformer.ts (1 hunks)
  • indexer/services/comlink/src/types.ts (1 hunks)
  • indexer/services/ender/__tests__/handlers/perpetual-market-handler.test.ts (3 hunks)
  • indexer/services/ender/__tests__/handlers/update-perpetual-handler.test.ts (2 hunks)
  • indexer/services/ender/__tests__/helpers/constants.ts (4 hunks)
  • indexer/services/ender/__tests__/helpers/indexer-proto-helpers.ts (2 hunks)
  • indexer/services/ender/__tests__/helpers/notification-functions.test.ts (1 hunks)
  • indexer/services/ender/__tests__/lib/on-message.test.ts (1 hunks)
  • indexer/services/ender/__tests__/validators/perpetual-market-validator.test.ts (4 hunks)
  • indexer/services/ender/__tests__/validators/update-perpetual-validator.test.ts (3 hunks)
  • indexer/services/ender/package.json (1 hunks)
  • indexer/services/ender/src/handlers/perpetual-market-handler.ts (3 hunks)
  • indexer/services/ender/src/helpers/kafka-helper.ts (1 hunks)
  • indexer/services/ender/src/helpers/postgres/postgres-functions.ts (2 hunks)
  • indexer/services/ender/src/lib/block-processor.ts (1 hunks)
  • indexer/services/ender/src/lib/helper.ts (3 hunks)
  • indexer/services/ender/src/lib/types.ts (4 hunks)
  • indexer/services/ender/src/scripts/handlers/dydx_block_processor_ordered_handlers.sql (2 hunks)
  • indexer/services/ender/src/scripts/handlers/dydx_perpetual_market_v3_handler.sql (1 hunks)
  • indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v3_handler.sql (1 hunks)
  • indexer/services/ender/src/validators/update-perpetual-validator.ts (1 hunks)
  • indexer/services/roundtable/__tests__/helpers/pnl-ticks-helper.test.ts (1 hunks)
  • indexer/services/roundtable/src/lib/athena-ddl-tables/perpetual_markets.ts (2 hunks)
  • indexer/services/roundtable/src/tasks/market-updater.ts (1 hunks)
  • proto/dydxprotocol/indexer/events/events.proto (5 hunks)
  • proto/dydxprotocol/perpetuals/perpetual.proto (1 hunks)
  • protocol/indexer/events/constants.go (1 hunks)
  • protocol/indexer/events/perpetual.go (2 hunks)
  • protocol/indexer/events/perpetual_market_create.go (2 hunks)
  • protocol/indexer/events/perpetual_market_create_test.go (2 hunks)
  • protocol/indexer/events/perpetual_test.go (1 hunks)
  • protocol/testutil/keeper/clob.go (1 hunks)
  • protocol/x/clob/abci_test.go (2 hunks)
  • protocol/x/clob/genesis_test.go (1 hunks)
  • protocol/x/clob/keeper/clob_pair.go (1 hunks)
  • protocol/x/clob/keeper/clob_pair_test.go (8 hunks)
  • protocol/x/clob/keeper/deleveraging_test.go (2 hunks)
  • protocol/x/clob/keeper/get_price_premium_test.go (1 hunks)
  • protocol/x/clob/keeper/liquidations_test.go (8 hunks)
  • protocol/x/clob/keeper/msg_server_create_clob_pair_test.go (1 hunks)
  • protocol/x/clob/keeper/msg_server_place_order_test.go (2 hunks)
  • protocol/x/clob/keeper/orders_test.go (4 hunks)
  • protocol/x/clob/keeper/process_operations_test.go (1 hunks)
  • protocol/x/clob/module_test.go (1 hunks)
  • protocol/x/listing/keeper/listing.go (1 hunks)
  • protocol/x/listing/keeper/msg_server_upgrade_isolated_perpetual_to_cross_test.go (2 hunks)
  • protocol/x/perpetuals/keeper/perpetual.go (1 hunks)
  • protocol/x/perpetuals/keeper/perpetual_test.go (3 hunks)
✅ Files skipped from review due to trivial changes (3)
  • indexer/packages/v4-protos/src/codegen/dydxprotocol/perpetuals/perpetual.ts
  • proto/dydxprotocol/perpetuals/perpetual.proto
  • protocol/x/clob/keeper/orders_test.go
🧰 Additional context used
📓 Learnings (4)
indexer/services/ender/src/helpers/postgres/postgres-functions.ts (2)
Learnt from: hwray
PR: dydxprotocol/v4-chain#2597
File: indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v1_handler.sql:16-20
Timestamp: 2024-11-22T18:12:04.606Z
Learning: Avoid suggesting changes to deprecated functions such as `dydx_update_perpetual_v1_handler` in `indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v1_handler.sql` if they are unchanged in the PR.
Learnt from: hwray
PR: dydxprotocol/v4-chain#2597
File: indexer/services/ender/src/helpers/postgres/postgres-functions.ts:47-48
Timestamp: 2024-11-22T18:12:38.778Z
Learning: Prefer to maintain old `v1` handler files, such as `dydx_update_perpetual_handler.sql`, instead of removing them, even when new versioned handlers are added.
indexer/services/ender/src/scripts/handlers/dydx_block_processor_ordered_handlers.sql (1)
Learnt from: hwray
PR: dydxprotocol/v4-chain#2597
File: indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v1_handler.sql:16-20
Timestamp: 2024-11-22T18:12:04.606Z
Learning: Avoid suggesting changes to deprecated functions such as `dydx_update_perpetual_v1_handler` in `indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v1_handler.sql` if they are unchanged in the PR.
indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v3_handler.sql (1)
Learnt from: hwray
PR: dydxprotocol/v4-chain#2597
File: indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v1_handler.sql:16-20
Timestamp: 2024-11-22T18:12:04.606Z
Learning: Avoid suggesting changes to deprecated functions such as `dydx_update_perpetual_v1_handler` in `indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v1_handler.sql` if they are unchanged in the PR.
indexer/services/ender/src/scripts/handlers/dydx_perpetual_market_v3_handler.sql (1)
Learnt from: hwray
PR: dydxprotocol/v4-chain#2597
File: indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v1_handler.sql:16-20
Timestamp: 2024-11-22T18:12:04.606Z
Learning: Avoid suggesting changes to deprecated functions such as `dydx_update_perpetual_v1_handler` in `indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v1_handler.sql` if they are unchanged in the PR.
🪛 LanguageTool
indexer/packages/postgres/README.md

[style] ~11-~11: Consider a shorter alternative to avoid wordiness.
Context: ... modified due to the latest migration. In order to migrate in dev and staging, you must re...

(IN_ORDER_TO_PREMIUM)

🪛 Biome (1.9.4)
indexer/services/ender/__tests__/handlers/perpetual-market-handler.test.ts

[error] 106-106: Don't use 'Function' as a type.

Prefer explicitly define the function shape. This type accepts any function-like value, which can be a common source of bugs.

(lint/complexity/noBannedTypes)

🪛 GitHub Actions: Protocol Lint
protocol/x/listing/keeper/msg_server_upgrade_isolated_perpetual_to_cross_test.go

[error] 236-236: Line length exceeds maximum limit: The line is 123 characters long, which exceeds the maximum of 120 characters

⏰ Context from checks skipped due to timeout of 90000ms (9)
  • GitHub Check: test-sim-multi-seed-short
  • GitHub Check: test-sim-after-import
  • GitHub Check: test-sim-import-export
  • GitHub Check: unit-end-to-end-and-integration
  • GitHub Check: test-race
  • GitHub Check: test-coverage-upload
  • GitHub Check: liveness-test
  • GitHub Check: container-tests
  • GitHub Check: Summary
🔇 Additional comments (62)
indexer/services/roundtable/src/lib/athena-ddl-tables/perpetual_markets.ts (1)

25-27: Verify naming convention for funding rate fields.

There's an inconsistency in naming between the protocol layer (DefaultFunding8HrPpm) and the database schema (defaultFundingRate1H). This suggests there might be a conversion happening between 8-hour and 1-hour rates. Please ensure:

  1. The conversion logic is properly documented
  2. The relationship between these rates is clear in the codebase
  3. Consider adding a comment explaining the conversion factor

Run this script to find related conversion logic:

Also applies to: 45-47

✅ Verification successful

Conversion between 8hr and 1hr funding rates is properly implemented.

The conversion from protocol's DefaultFunding8HrPpm to database's defaultFundingRate1H is implemented in the indexer:

  • 8hr rate in PPM is converted to decimal: rate_ppm / 1_000_000
  • 8hr rate is converted to 1hr rate: 8hr_rate / 8

The naming difference reflects the different time periods and formats used in each layer. Consider adding a comment explaining this conversion in the database schema.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for funding rate conversion logic between 8hr and 1hr rates
rg -A 5 -e "8[Hh]r.*1[Hh]|1[Hh]r.*8[Hh]r" --type ts --type go

Length of output: 65600


Script:

#!/bin/bash
# Search for DefaultFunding8HrPpm and defaultFundingRate1H definitions and usages
rg -A 3 "DefaultFunding8HrPpm|defaultFundingRate1H" --type ts --type go

# Also search for any comments or code mentioning funding rate conversion
rg -A 3 "funding.*rate.*conversion|convert.*funding.*rate" --type ts --type go

Length of output: 14144

protocol/indexer/events/constants.go (1)

35-35: LGTM! Version updates align with the new field addition.

The version increments for both PerpetualMarketEventVersion and UpdatePerpetualEventVersion correctly reflect the addition of the defaultFunding8hrPpm field to these events.

Also applies to: 37-37

indexer/packages/postgres/__tests__/db/migrations.test.ts (2)

26-35: LGTM! Clear test description for the migration test.

The test description clearly indicates that this is testing both UP and DOWN migrations without seed data.


37-50: Well-documented test skips with clear guidance.

The skip messages are properly documented with:

  1. Clear warning about model modifications
  2. Reference to README for more information
  3. Descriptive test names indicating their purpose

This helps developers understand why tests are skipped and how to handle them in future migrations.

Also applies to: 53-67

indexer/services/ender/__tests__/validators/update-perpetual-validator.test.ts (1)

7-7: LGTM! Proper import and constant additions.

The new UpdatePerpetualEventV3 is correctly imported and its default constant is added.

Also applies to: 16-16

indexer/packages/postgres/src/models/perpetual-market-model.ts (1)

89-89: LGTM! Well-structured model changes for the new funding rate field.

The defaultFundingRate1H field is properly implemented with:

  1. Correct JSON schema definition including null handling and pattern validation
  2. Proper SQL to JSON conversion mapping
  3. Optional class property

Also applies to: 119-119, 157-157

indexer/services/ender/src/helpers/postgres/postgres-functions.ts (1)

41-41: LGTM! Handler scripts for V3 events added correctly.

The new handler scripts for V3 perpetual market events are added consistently with the existing pattern.

Also applies to: 50-50

indexer/services/ender/__tests__/helpers/notification-functions.test.ts (1)

54-54: LGTM! Test mock updated with new funding rate field.

The defaultFundingRate1H field is added to the mockMarket object with a sensible default value.

indexer/services/ender/__tests__/validators/perpetual-market-validator.test.ts (1)

5-5: LGTM! Test coverage properly extended for V3 events.

The test suite is correctly updated to include validation for the new V3 event type, maintaining consistency with existing test patterns.

Also applies to: 16-16, 54-59, 64-65, 95-96, 104-105, 113-114, 119-120

indexer/services/roundtable/src/tasks/market-updater.ts (1)

73-73: Verify the TODO implementation plan for default funding rate.

The TODO comment (CT-1340) indicates that default funding rate needs to be added to the next funding value. This aligns with the PR objectives of introducing the defaultFunding8hrPpm field.

Would you like me to help implement the logic for adding the default funding rate to the next funding value? This would ensure consistency with the new defaultFunding8hrPpm field being introduced.

protocol/x/clob/keeper/msg_server_create_clob_pair_test.go (1)

67-67: LGTM! DefaultFundingPpm correctly added to event creation test.

The test has been properly updated to include the new DefaultFundingPpm field in the NewPerpetualMarketCreateEvent creation, ensuring the new field is properly tested.

indexer/packages/postgres/src/types/websocket-message-types.ts (1)

220-220: LGTM! Type definition properly added for defaultFundingRate1H.

The optional string field defaultFundingRate1H has been correctly added to the TradingPerpetualMarketMessage interface, maintaining consistency with other funding-related fields.

protocol/x/clob/keeper/get_price_premium_test.go (1)

188-188: LGTM! DefaultFundingPpm correctly added to price premium test.

The test has been properly updated to include the new DefaultFundingPpm field in the NewPerpetualMarketCreateEvent creation, maintaining consistency with other test files.

indexer/services/ender/__tests__/handlers/perpetual-market-handler.test.ts (3)

4-4: LGTM! Import statements are correctly updated.

The imports are properly organized to include the new V3 event type and its corresponding helper functions.

Also applies to: 33-33, 39-39


95-101: LGTM! Test case for V3 event is properly structured.

The test case follows the existing pattern and correctly includes all necessary parameters for testing the V3 event.


107-108: LGTM! Type signature is properly updated.

The function parameter type is correctly extended to include the V3 event type.

protocol/x/listing/keeper/listing.go (1)

206-206: LGTM! Default funding parameter is correctly included.

The DefaultFundingPpm is properly sourced from the perpetual's params and included in the event emission, aligning with the PR objectives.

indexer/services/ender/src/lib/types.ts (2)

10-10: LGTM! Import statements are correctly updated.

The imports properly include the new V3 event types.

Also applies to: 36-36


133-138: LGTM! Event type definitions are properly extended.

The union type definitions correctly include the V3 events while maintaining the existing structure.

Also applies to: 163-168

indexer/packages/postgres/src/types/db-model-types.ts (1)

98-98: LGTM! Database model type is properly extended.

The defaultFundingRate1H field is correctly defined as an optional string field and follows the interface's naming convention.

protocol/x/listing/keeper/msg_server_upgrade_isolated_perpetual_to_cross_test.go (1)

Line range hint 250-265: LGTM!

The function has been correctly updated to handle the new UpdatePerpetualEventV3 type while maintaining the existing logic and error handling.

protocol/testutil/keeper/clob.go (1)

351-351: LGTM!

The mock indexer event has been correctly updated to include the new DefaultFundingPpm field.

indexer/services/ender/src/helpers/kafka-helper.ts (1)

350-350: LGTM!

The perpetual market message has been correctly updated to include the new defaultFundingRate1H field.

indexer/services/ender/src/lib/helper.ts (3)

21-21: LGTM!

The new event types are correctly imported and properly organized within the import statements.

Also applies to: 26-26


176-183: LGTM!

The version 3 case for perpetual market events is correctly implemented, following the existing pattern and maintaining consistent error handling.


228-235: LGTM!

The version 3 case for update perpetual events is correctly implemented, following the existing pattern and maintaining consistent error handling.

indexer/services/comlink/__tests__/lib/request-helpers/request-transformer.test.ts (1)

84-84: LGTM! Test updated to include new funding rate field.

The test correctly verifies that defaultFundingRate1H is included in the response object from perpetualMarketToResponseObject.

indexer/services/ender/src/lib/block-processor.ts (1)

52-52: LGTM! Added validators for version 3 perpetual market events.

The block processor has been updated to handle version 3 of both PERPETUAL_MARKET and UPDATE_PERPETUAL events, which include the new funding rate field.

Also applies to: 56-56

indexer/services/ender/__tests__/helpers/constants.ts (2)

165-178: LGTM! Added test constant for PerpetualMarketCreateEventV3.

The new constant correctly includes all required fields including the new defaultFunding8hrPpm field.


229-237: LGTM! Added test constant for UpdatePerpetualEventV3.

The new constant correctly includes all required fields including the new defaultFunding8hrPpm field, maintaining consistency with the create event constant.

protocol/x/clob/genesis_test.go (1)

456-456: LGTM! Updated genesis test to include funding parameter.

The test has been properly updated to include defaultFundingPpm when creating perpetual market events during genesis initialization.

protocol/x/clob/module_test.go (1)

313-313: LGTM: DefaultFundingPpm parameter correctly added to event creation

The addition of perpetual.Params.DefaultFundingPpm to the NewPerpetualMarketCreateEvent call is consistent with the PR's objective of including funding rate information in perpetual market events.

indexer/services/roundtable/__tests__/helpers/pnl-ticks-helper.test.ts (1)

385-385: LGTM: Test data updated with defaultFundingRate1H

The addition of defaultFundingRate1H: '0.0001' to the test data is appropriate and uses a realistic value (0.01% per hour) for testing purposes.

protocol/x/clob/keeper/msg_server_place_order_test.go (2)

186-186: LGTM: DefaultFundingPpm parameter added to error test case

The addition of perpetual.Params.DefaultFundingPpm to the event creation in the error test case ensures complete test coverage of the funding rate information.


338-338: LGTM: DefaultFundingPpm parameter added to success test case

The addition of perpetual.Params.DefaultFundingPpm to the event creation in the success test case maintains consistency with the error test case and ensures proper testing of the funding rate information.

indexer/services/comlink/src/request-helpers/request-transformer.ts (1)

392-392: LGTM!

The addition of defaultFundingRate1H to the response object is straightforward and correctly maps the field from the database object.

protocol/x/clob/keeper/clob_pair.go (1)

164-164: LGTM!

The addition of DefaultFundingPpm to the perpetual market create event is correct and aligns with the PR objectives.

indexer/services/ender/__tests__/helpers/indexer-proto-helpers.ts (1)

975-997: Verify the funding rate calculation.

The conversion of defaultFunding8hrPpm to defaultFundingRate1H involves two steps:

  1. Converting PPM (parts per million) to decimal by dividing by 1,000,000
  2. Converting 8-hour rate to 1-hour rate by dividing by 8

Please verify that this calculation aligns with the business requirements and protocol specifications.

Run this script to find other instances of funding rate calculations in the codebase:

✅ Verification successful

Funding rate calculation verified ✓

The conversion of defaultFunding8hrPpm to defaultFundingRate1H is correctly implemented and consistent with the protocol specifications, as evidenced by multiple implementations and test cases throughout the codebase.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Find other instances of funding rate calculations to verify consistency
# Search for files containing both "funding" and "ppm" or "rate"
rg -l "funding.*(?:ppm|rate)" | xargs rg "(?:ppm|rate).*funding"

Length of output: 5761

indexer/services/ender/__tests__/lib/on-message.test.ts (1)

255-256: LGTM! Test name is now more descriptive.

The test case name has been updated to be more specific about the version being tested (PerpetualMarketCreateV2), which improves test clarity.

protocol/x/clob/keeper/clob_pair_test.go (1)

Line range hint 530-530: LGTM! Test coverage for default funding parameter.

The test cases correctly include DefaultFundingPpm in perpetual market creation events, maintaining test coverage for the new funding parameter.

Also applies to: 563-564

protocol/x/perpetuals/keeper/perpetual.go (1)

176-176: LGTM! Funding parameter included in update events.

The DefaultFundingPpm is correctly included in the perpetual update event, ensuring consistency with the event schema.

protocol/x/clob/abci_test.go (1)

530-530: LGTM! Test coverage for default funding parameter.

The test cases correctly include DefaultFundingPpm in event expectations, maintaining test coverage for the new funding parameter.

Also applies to: 563-564

protocol/x/clob/keeper/deleveraging_test.go (1)

288-288: LGTM! Test setup correctly updated to include DefaultFundingPpm parameter.

The changes correctly update the mock event creation to include the new DefaultFundingPpm parameter from the perpetual's parameters, ensuring test coverage of the new event field.

Also applies to: 686-686

protocol/x/perpetuals/keeper/perpetual_test.go (1)

Line range hint 45-71: LGTM! Test code correctly updated to use V3 event type with DefaultFunding8HrPpm field.

The changes properly update the test code to:

  1. Use the new UpdatePerpetualEventV3 type instead of V2
  2. Include expectations for the new DefaultFunding8HrPpm field
  3. Update helper functions to handle the V3 event structure

Also applies to: 118-133

protocol/x/clob/keeper/process_operations_test.go (1)

2459-2459: LGTM! Test setup correctly updated to include DefaultFundingPpm parameter.

The change properly updates the mock event creation to include the new DefaultFundingPpm parameter from the perpetual's parameters, maintaining consistency with the new event structure.

indexer/packages/v4-protos/src/codegen/dydxprotocol/indexer/events/events.ts (2)

962-966: Well-documented deprecation notices!

The deprecation notices clearly indicate that users should use the V3 versions of these events instead.

Also applies to: 1496-1500


3579-3732: Clean and consistent implementations of the V3 events.

The implementations:

  • Properly handle all fields including the new defaultFunding8hrPpm
  • Follow protobuf encoding/decoding patterns
  • Include proper null checks and default values
  • Use consistent type handling across both event types

Also applies to: 4084-4187

protocol/x/clob/keeper/liquidations_test.go (1)

1253-1253: LGTM: DefaultFundingPpm field added to test events

The changes correctly add the DefaultFundingPpm field to PerpetualMarketCreateEvent in test cases, maintaining test coverage for the new field.

Also applies to: 1284-1284

indexer/services/ender/src/handlers/perpetual-market-handler.ts (1)

6-9: LGTM: PerpetualMarketCreateEventV3 integration

The addition of PerpetualMarketCreateEventV3 to imports and type union properly extends the handler to support the new event version.

Also applies to: 19-19

proto/dydxprotocol/indexer/events/events.proto (3)

377-429: LGTM! Proper deprecation of V2 message.

The deprecation of PerpetualMarketCreateEventV2 is well documented and follows protobuf best practices.


Line range hint 431-484: LGTM! Well-structured V3 message definition.

The new PerpetualMarketCreateEventV3 message is properly documented and maintains consistent field numbering with the addition of default_funding8hr_ppm.


Line range hint 579-641: LGTM! Consistent versioning pattern for UpdatePerpetualEvent.

The changes follow the same versioning pattern, properly deprecating V2 and introducing V3 with the new funding rate field.

indexer/services/comlink/public/api-documentation.md (2)

2509-2510: LGTM! New fields added to PerpetualMarketResponseObject

The addition of baseOpenInterest and defaultFundingRate1H fields to the response schema is well-structured and follows the API's naming conventions.


5456-5457: LGTM! Consistent schema updates in PerpetualMarketResponse

The new fields are consistently added across all example properties in the markets object, maintaining the API documentation's structure and clarity.

Also applies to: 5480-5481

indexer/packages/postgres/__tests__/helpers/constants.ts (1)

288-288: LGTM! Consistent funding rate values.

The defaultFundingRate1H values are consistently set across similar market types:

  • '0' for default perpetual markets
  • '0.0001' for isolated perpetual markets

Also applies to: 308-308, 328-328, 349-349, 370-370

indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v3_handler.sql (3)

12-13: LGTM! Well-defined constants for funding rate calculation.

The constants are appropriately defined for converting 8-hour funding rate to 1-hour rate:

  • PPM_EXPONENT = -6 for parts per million scaling
  • FUNDING_RATE_FROM_PROTOCOL_IN_HOURS = 8 for converting from 8hr to 1hr rate

23-26: LGTM! Correct funding rate conversion formula.

The calculation correctly:

  1. Scales the PPM value using power(10, PPM_EXPONENT)
  2. Converts from 8hr to 1hr rate by dividing by FUNDING_RATE_FROM_PROTOCOL_IN_HOURS
  3. Uses dydx_trim_scale for consistent decimal handling

38-40: LGTM! Proper error handling for non-existent markets.

The function appropriately raises an exception when the perpetual market is not found.

indexer/services/ender/src/scripts/handlers/dydx_perpetual_market_v3_handler.sql (2)

21-25: LGTM! Proper initialization of market metrics.

All market metrics are correctly initialized to zero:

  • priceChange24H
  • trades24H
  • volume24H
  • nextFundingRate
  • openInterest

33-36: LGTM! Consistent funding rate calculation.

The funding rate calculation is identical to the update handler, ensuring consistency in rate conversion across handlers.

indexer/services/ender/src/scripts/handlers/dydx_block_processor_ordered_handlers.sql (1)

59-60: LGTM! Proper integration of v3 handlers.

The v3 handlers are correctly added to both event types:

  • perpetual_market: Added case for version 3
  • update_perpetual: Added case for version 3

The changes maintain the existing pattern and include proper fallback to NULL for unknown versions.

Also applies to: 72-73

indexer/services/comlink/public/swagger.json (1)

1141-1143: Verify field name consistency with PR objectives.

The field name defaultFundingRate1H suggests a 1-hour funding rate, while the PR objectives mention defaultFunding8hrPpm. This naming inconsistency could lead to confusion. Consider either:

  1. Renaming to match PR objectives if this field should represent 8-hour PPM rate
  2. Clarifying in PR objectives if this is an intentional conversion from 8-hour to 1-hour rate
✅ Verification successful

Field name is correct and consistent with codebase design

The field name defaultFundingRate1H in swagger.json is correct. The protocol internally uses 8-hour funding rates, but the indexer converts these to 1-hour rates for API responses, as evidenced by the funding8HourValuePpmTo1HourRate conversion function in the codebase. This is a deliberate design pattern where 8hr protocol-level rates are converted to 1hr rates for client consumption.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Search for related funding rate fields and conversions
# Look for other funding rate related fields and potential conversions between 1h and 8h rates
rg -A 5 -B 5 'funding.*rate|ppm' --type ts --type go

Length of output: 71463


export async function up(knex: Knex): Promise<void> {
await knex.schema.alterTable('perpetual_markets', (table) => {
table.decimal('defaultFundingRate1H', null).defaultTo(0);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🛠️ Refactor suggestion

Specify decimal precision for funding rate column.

The decimal type without precision and scale could lead to data truncation or inconsistency. Consider specifying appropriate precision and scale parameters based on the expected range of funding rates.

-    table.decimal('defaultFundingRate1H', null).defaultTo(0);
+    table.decimal('defaultFundingRate1H', 30, 18).defaultTo(0);
📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
table.decimal('defaultFundingRate1H', null).defaultTo(0);
table.decimal('defaultFundingRate1H', 30, 18).defaultTo(0);

Comment on lines +23 to +24
defaultFundingPpm int32,
) *PerpetualMarketCreateEventV3 {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🛠️ Refactor suggestion

Add validation for defaultFundingPpm parameter.

Consider adding validation for the defaultFundingPpm parameter to ensure it falls within acceptable bounds for a funding rate. This could prevent issues with extreme or invalid values.

Example validation:

 func NewPerpetualMarketCreateEvent(
   // ... other parameters ...
   defaultFundingPpm int32,
 ) *PerpetualMarketCreateEventV3 {
+  // Validate funding rate is within acceptable bounds
+  // For example: -10000 to 10000 for ±1% (10000 PPM = 1%)
+  if defaultFundingPpm < -10000 || defaultFundingPpm > 10000 {
+    panic(fmt.Sprintf("defaultFundingPpm %d is outside acceptable range [-10000, 10000]", defaultFundingPpm))
+  }
   return &PerpetualMarketCreateEventV3{
     // ... other fields ...
     DefaultFunding8HrPpm: defaultFundingPpm,
   }
 }

Committable suggestion skipped: line range outside the PR's diff.

@@ -18,6 +18,7 @@ export interface PerpetualMarketCreateObject {
liquidityTierId: number,
marketType: PerpetualMarketType,
baseOpenInterest: string,
defaultFundingRate1H: string,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️ Potential issue

Add defaultFundingRate1H to PerpetualMarketUpdateObject.

The defaultFundingRate1H field is added to PerpetualMarketCreateObject but missing from PerpetualMarketUpdateObject. If this field should be updatable, add it to the update interface:

 export interface PerpetualMarketUpdateObject {
   // ... existing fields ...
   liquidityTierId?: number,
+  defaultFundingRate1H?: string,
 }

Also applies to: 24-41

Comment on lines +61 to +64
'UpdatePerpetualEventV3',
UpdatePerpetualEventV3.encode(defaultUpdatePerpetualEventV3).finish(),
defaultUpdatePerpetualEventV2,
],
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️ Potential issue

Fix incorrect event version in test data.

The test is using defaultUpdatePerpetualEventV2 for V3 event test case. This should be using defaultUpdatePerpetualEventV3 instead.

Apply this fix:

-      defaultUpdatePerpetualEventV2,
+      defaultUpdatePerpetualEventV3,
📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
'UpdatePerpetualEventV3',
UpdatePerpetualEventV3.encode(defaultUpdatePerpetualEventV3).finish(),
defaultUpdatePerpetualEventV2,
],
'UpdatePerpetualEventV3',
UpdatePerpetualEventV3.encode(defaultUpdatePerpetualEventV3).finish(),
defaultUpdatePerpetualEventV3,
],

MarketId: perpetual.Params.MarketId,
AtomicResolution: perpetual.Params.AtomicResolution,
LiquidityTier: perpetual.Params.LiquidityTier,
MarketType: v1.ConvertToPerpetualMarketType(perpetualtypes.PerpetualMarketType_PERPETUAL_MARKET_TYPE_CROSS),
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️ Potential issue

Fix line length to comply with linting rules.

The line exceeds the maximum length of 120 characters.

Apply this diff to fix the line length:

-            MarketType:           v1.ConvertToPerpetualMarketType(perpetualtypes.PerpetualMarketType_PERPETUAL_MARKET_TYPE_CROSS),
+            MarketType: v1.ConvertToPerpetualMarketType(
+              perpetualtypes.PerpetualMarketType_PERPETUAL_MARKET_TYPE_CROSS,
+            ),
📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
MarketType: v1.ConvertToPerpetualMarketType(perpetualtypes.PerpetualMarketType_PERPETUAL_MARKET_TYPE_CROSS),
MarketType: v1.ConvertToPerpetualMarketType(
perpetualtypes.PerpetualMarketType_PERPETUAL_MARKET_TYPE_CROSS,
),
🧰 Tools
🪛 GitHub Actions: Protocol Lint

[error] 236-236: Line length exceeds maximum limit: The line is 123 characters long, which exceeds the maximum of 120 characters

Comment on lines +1183 to +1185
/** Default 8hr funding rate in parts-per-million. */

defaultFunding8hrPpm: number;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

💡 Codebase verification

Update required in market updater for the new funding rate field

The defaultFunding8hrPpm field is properly handled in database schemas, but the market updater needs to be updated to use this field:

  • indexer/services/roundtable/src/tasks/market-updater.ts: Unresolved TODO (CT-1340) to add default funding rate
🔗 Analysis chain

Verify handling of the new funding rate field in dependent systems.

The addition of defaultFunding8hrPpm may require updates to systems that:

  • Parse and process these events
  • Store event data in databases
  • Display funding rate information in UIs

Please ensure all dependent systems are updated to handle this new field.

Also applies to: 1624-1626

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for systems that need to be updated to handle the new field

# Find event handlers
echo "Searching for event handlers..."
rg -l "PerpetualMarketCreateEventV[12]|UpdatePerpetualEventV[12]"

# Find database schemas/migrations
echo "Searching for database schemas..."
fd -e sql -e prisma -e graphql

# Find UI components
echo "Searching for UI components..."
rg -l "funding.*rate|funding.*ppm"

Length of output: 8789


Script:

#!/bin/bash
# Check funding handlers and database schema for the new field

# Check handlers and validators
echo "Checking handlers and validators..."
rg -A 5 "defaultFunding8hrPpm" indexer/services/ender/src/

# Check database schema
echo "Checking database schema..."
rg "funding.*ppm|funding.*rate" indexer/services/ender/src/scripts/handlers/dydx_funding_handler.sql

# Check if field is used in market updates
echo "Checking market updater..."
rg -A 5 "funding.*ppm|funding.*rate" indexer/services/roundtable/src/tasks/market-updater.ts

Length of output: 2262


Script:

#!/bin/bash
# Check for TODO ticket and recent changes

# Search for the ticket number
echo "Searching for ticket reference..."
rg "CT-1340"

# Check git history for recent changes to market updater
echo "Checking recent changes..."
git log -p -- indexer/services/roundtable/src/tasks/market-updater.ts | grep -A 5 "funding.*rate"

Length of output: 280

@@ -22,6 +26,7 @@ export class PerpetualMarketCreationHandler extends Handler<

// eslint-disable-next-line @typescript-eslint/require-await
public async internalHandle(resultRow: pg.QueryResultRow): Promise<ConsolidatedKafkaEvent[]> {
console.log(resultRow);
Copy link
Contributor

@coderabbitai coderabbitai bot Jan 14, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🛠️ Refactor suggestion

Remove debugging console.log statement

This console.log statement appears to be debugging code and should be removed before merging.

-    console.log(resultRow);

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit: Remove console log.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@vincentwschau Agreed, I'll remove the console.log statement.


If you found this review helpful, would you consider giving us a shout-out on X?
Thank you for using CodeRabbit!

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Nitpick comments (5)
indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v3_handler.sql (5)

1-10: Enhance documentation with version change details.

Please add documentation explaining:

  • What changes were introduced in v3 compared to v2
  • The purpose and format of the new defaultFunding8hrPpm field

12-13: Document the constants and their derivation.

Please add comments explaining:

  • Why PPM_EXPONENT is set to -6 (parts per million conversion)
  • The rationale behind the 8-hour to 1-hour funding rate conversion

17-26: Add input validation and improve calculation readability.

Consider these improvements:

  1. Add validation for required fields in event_data
  2. Break down the funding rate calculation into intermediate steps for better readability

Example refactor for the funding rate calculation:

-    perpetual_market_record."defaultFundingRate1H" = dydx_trim_scale(
-      power(10, PPM_EXPONENT) /
-      FUNDING_RATE_FROM_PROTOCOL_IN_HOURS *
-      (event_data->'defaultFunding8hrPpm')::numeric);
+    -- Convert 8hr funding rate (PPM) to 1hr rate
+    perpetual_market_record."defaultFundingRate1H" = dydx_trim_scale((
+      SELECT
+        funding_rate_8h_ppm * power(10, PPM_EXPONENT) / FUNDING_RATE_FROM_PROTOCOL_IN_HOURS
+      FROM (
+        SELECT NULLIF((event_data->'defaultFunding8hrPpm')::numeric, 0) as funding_rate_8h_ppm
+      ) sub
+    ));

27-36: Consider transaction safety and concurrent updates.

The UPDATE operation might benefit from:

  1. Explicit transaction management
  2. Optimistic locking or version column to handle concurrent updates

38-45: Enhance error handling and add logging.

Consider these improvements:

  1. Include more context in the error message (e.g., ticker, marketId)
  2. Add logging for successful updates and error cases
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between ca540a6 and 817c64e.

📒 Files selected for processing (2)
  • indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v2_handler.sql (1 hunks)
  • indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v3_handler.sql (1 hunks)
✅ Files skipped from review due to trivial changes (1)
  • indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v2_handler.sql
🧰 Additional context used
📓 Learnings (1)
indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v3_handler.sql (1)
Learnt from: hwray
PR: dydxprotocol/v4-chain#2597
File: indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v1_handler.sql:16-20
Timestamp: 2024-11-22T18:12:04.606Z
Learning: Avoid suggesting changes to deprecated functions such as `dydx_update_perpetual_v1_handler` in `indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v1_handler.sql` if they are unchanged in the PR.
⏰ Context from checks skipped due to timeout of 90000ms (21)
  • GitHub Check: install-runsim
  • GitHub Check: call-build-ecs-service-vulcan / (vulcan) Check docker image build
  • GitHub Check: call-build-ecs-service-socks / (socks) Check docker image build
  • GitHub Check: call-build-ecs-service-ender / (ender) Check docker image build
  • GitHub Check: call-build-ecs-service-roundtable / (roundtable) Check docker image build
  • GitHub Check: test / run_command
  • GitHub Check: call-build-ecs-service-comlink / (comlink) Check docker image build
  • GitHub Check: test-race
  • GitHub Check: check-build-bazooka
  • GitHub Check: unit-end-to-end-and-integration
  • GitHub Check: check-build-auxo
  • GitHub Check: golangci-lint
  • GitHub Check: test-coverage-upload
  • GitHub Check: container-tests
  • GitHub Check: liveness-test
  • GitHub Check: benchmark
  • GitHub Check: check-sample-pregenesis-up-to-date
  • GitHub Check: run_command
  • GitHub Check: Analyze (javascript-typescript)
  • GitHub Check: Analyze (go)
  • GitHub Check: Summary
🔇 Additional comments (1)
indexer/services/ender/src/scripts/handlers/dydx_update_perpetual_v3_handler.sql (1)

1-47: Verify handler registration and data migration.

Please ensure:

  1. The v3 handler is properly registered in the block processor
  2. A migration plan exists for updating existing perpetual markets
✅ Verification successful

Handler is properly registered and no migration is required

The v3 handler is correctly registered in the block processor and maintains backward compatibility with the existing table structure. No explicit migration is needed as it's a compatible handler upgrade that uses the same table structure.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check if the handler is properly registered
rg -A 5 "dydx_update_perpetual_v3_handler" indexer/services/ender/src/

# Look for related migrations
fd -e sql . indexer/services/ender/src/migrations/

Length of output: 3617


Script:

#!/bin/bash
# Find migrations directory
fd migrations

# Check table structure and any migration files
rg -g '*.sql' -i 'perpetual.*markets' .

Length of output: 5583


Script:

#!/bin/bash
# Check migrations in the correct directory
rg -g '*.sql' -A 5 'perpetual.*markets' indexer/packages/postgres/src/db/migrations/

# Also check for any table creation scripts
rg -g '*.sql' -A 5 'CREATE TABLE.*perpetual.*markets' indexer/packages/postgres/src/db/migrations/

Length of output: 187

@@ -252,7 +252,8 @@ describe('on-message', () => {
expect.any(Number), 1, { success: 'true' });
});

it('successfully processes block with market create and its funding events', async () => {
// NEXT!! both V2 and V3
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit: todo?

Comment on lines +64 to 72
expectedIndexerEvents[i] = &indexerevents.UpdatePerpetualEventV3{
Id: item.Params.Id,
Ticker: ticker,
MarketId: marketId,
AtomicResolution: item.Params.AtomicResolution,
LiquidityTier: liquidityTier,
MarketType: v1.ConvertToPerpetualMarketType(item.Params.MarketType),
DefaultFunding8HrPpm: defaultFundingPpm,
}
Copy link
Contributor

@hwray hwray Jan 15, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

blanket comment for tests: are we testing / do we need to test the case where DefaultFunding is nil?

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

Successfully merging this pull request may close these issues.

3 participants