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(NODE-6520): add client side operations timeoutMS #4095

Merged
merged 35 commits into from
Nov 6, 2024
Merged

Conversation

W-A-James
Copy link
Contributor

@W-A-James W-A-James commented Apr 23, 2024

Description

What is changing?

New Error
  • Added MongoOperationTimeoutError class that is thrown when a CSOT timeout is encountered
Changes to Timeout
  • Add Timeout.throwIfExpired() method
  • Add Timeout.remainingTime getter method
Updates to AbstractOperation
  • Add timeout field
    • timeout is set at construction if the timeoutMS option is provided
Implementing CSOT behaviour for server selection
  • Update Topology.selectServer to accept a timeout option which it will use determine whether it has timed out when defined. Otherwise, constructs a Timeout using the serverSelectionMS option as before
  • Update Topology.selectServer to throw a MongoOperationTimeoutError on timeout when options.timeout is provided and retain previous error behaviour otherwise.
  • Update Topology._connect to pass down timeout to Server.command call used to execute ping on first connection
Implementing CSOT behaviour for connection checkout
  • Update Server.command to accept timeout option.
  • Update ConnectionPool.checkOut to accept timeout option
    • only uses the passed in timeout if the configured serverSelectionTimeoutMS is greater than the duration on the timeout, otherwise, computes the time elapsed since server selection completed and creates timeout for the serverSelectionTimeoutMS deadline
Test changes
  • Implement Server Selection prose tests from CSOT spec. Left out last two since they require implementation of the connection creation cancellation behaviour that was decided against in DRIVERS-2347
  • Implement unit tests from CSOT spec related to server selection and connection checkout. Skipped tests with appropriate messages
Misc changes
  • Update resolveOptions to handle timeoutMS option propagation
    • Add csotMin helper method that implements the CSOT min algorithm described here
Is there new documentation needed for these changes?

What is the motivation for this change?

Release Highlight

PLACEHOLDER FOR CSOT FEATURE HIGHLIGHT

Double check the following

  • Ran npm run check:lint script
  • Self-review completed using the steps outlined here
  • PR title follows the correct format: type(NODE-xxxx)[!]: description
    • Example: feat(NODE-1234)!: rewriting everything in coffeescript
  • Changes are covered by tests
  • New TODOs have a related JIRA ticket

@W-A-James W-A-James force-pushed the NODE-6090 branch 2 times, most recently from 5688ba8 to b878c6c Compare April 26, 2024 23:48
src/cmap/connect.ts Outdated Show resolved Hide resolved
src/cmap/connect.ts Outdated Show resolved Hide resolved
src/cmap/connection.ts Outdated Show resolved Hide resolved
src/cmap/connection_pool.ts Outdated Show resolved Hide resolved
src/cmap/connection_pool.ts Outdated Show resolved Hide resolved
src/error.ts Outdated Show resolved Hide resolved
src/operations/operation.ts Outdated Show resolved Hide resolved
@W-A-James W-A-James changed the title Node 6090 refactor(NODE-6090): Implement CSOT logic for server selection and connection checkout May 3, 2024
@W-A-James W-A-James changed the base branch from main to CSOT-feature May 3, 2024 21:27
src/admin.ts Show resolved Hide resolved
@W-A-James
Copy link
Contributor Author

Evergreen link

@W-A-James W-A-James marked this pull request as ready for review May 3, 2024 22:19
Copy link
Contributor

@baileympearson baileympearson left a comment

Choose a reason for hiding this comment

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

left some small comments. I'm out this week, so don't consider them blocking!

src/sdam/server.ts Outdated Show resolved Hide resolved
src/sdam/server.ts Outdated Show resolved Hide resolved
src/sdam/server.ts Outdated Show resolved Hide resolved
src/operations/operation.ts Outdated Show resolved Hide resolved
src/sdam/topology.ts Show resolved Hide resolved
src/operations/execute_operation.ts Outdated Show resolved Hide resolved
@aditi-khare-mongoDB aditi-khare-mongoDB added Primary Review In Review with primary reviewer, not yet ready for team's eyes and removed Primary Review In Review with primary reviewer, not yet ready for team's eyes labels May 6, 2024
@nbbeeken nbbeeken self-requested a review May 6, 2024 16:07
@aditi-khare-mongoDB aditi-khare-mongoDB self-requested a review May 6, 2024 17:25
@aditi-khare-mongoDB aditi-khare-mongoDB self-assigned this May 6, 2024
@aditi-khare-mongoDB aditi-khare-mongoDB added the Primary Review In Review with primary reviewer, not yet ready for team's eyes label May 6, 2024
@aditi-khare-mongoDB
Copy link
Contributor

Bookkeeping:
Waiting for Warren to respond to Bailey's comments and will proceed with review then.

@W-A-James W-A-James changed the base branch from CSOT-feature to main May 7, 2024 17:45
src/sdam/topology.ts Outdated Show resolved Hide resolved
src/sdam/server.ts Outdated Show resolved Hide resolved
src/sdam/topology.ts Outdated Show resolved Hide resolved
@W-A-James
Copy link
Contributor Author

@aditi-khare-mongoDB @nbbeeken should we conditionally clear the timeout on success/a non-timeout failure based on whether or not we created the timeout inside the function that we race the timeout with?
I ask because we don't always own Timeout instance we're using in Topology.selectServer or in ConnectionPool.checkOut.

src/cmap/connection_pool.ts Outdated Show resolved Hide resolved
aditi-khare-mongoDB and others added 17 commits November 5, 2024 15:04
…4243)

Co-authored-by: Warren James <[email protected]>
Co-authored-by: Neal Beeken <[email protected]>
Co-authored-by: Bailey Pearson <[email protected]>
Co-authored-by: Warren James <[email protected]>
Co-authored-by: Neal Beeken <[email protected]>
Co-authored-by: Bailey Pearson <[email protected]>
Co-authored-by: Neal Beeken <[email protected]>
Co-authored-by: Aditi Khare <[email protected]>
etc/notes/errors.md Outdated Show resolved Hide resolved
src/client-side-encryption/auto_encrypter.ts Outdated Show resolved Hide resolved
src/collection.ts Outdated Show resolved Hide resolved
src/gridfs/download.ts Outdated Show resolved Hide resolved
src/gridfs/upload.ts Outdated Show resolved Hide resolved
src/sdam/topology.ts Outdated Show resolved Hide resolved
src/sessions.ts Show resolved Hide resolved
test/unit/index.test.ts Show resolved Hide resolved
test/unit/operations/get_more.test.ts Outdated Show resolved Hide resolved
@nbbeeken nbbeeken requested a review from dariakp November 6, 2024 16:25
Copy link
Contributor

@dariakp dariakp left a comment

Choose a reason for hiding this comment

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

LGTM pending perf comparison

@dariakp dariakp added the Blocked Blocked on other work label Nov 6, 2024
@dariakp dariakp removed the Blocked Blocked on other work label Nov 6, 2024
@dariakp dariakp dismissed baileympearson’s stale review November 6, 2024 22:38

Everything is addressed

@dariakp dariakp changed the title feat(NODE-6197): add client side operations timeoutMS feat(NODE-6520): add client side operations timeoutMS Nov 6, 2024
@dariakp dariakp merged commit e5582ed into main Nov 6, 2024
29 checks passed
@dariakp dariakp deleted the NODE-6090 branch November 6, 2024 22:52
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Team Review Needs review from team
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants