-
Notifications
You must be signed in to change notification settings - Fork 896
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
GODRIVER-3217 Use the manually-specified maxTimeMS on Find and Aggregate if it would be ommitted by CSOT #1644
GODRIVER-3217 Use the manually-specified maxTimeMS on Find and Aggregate if it would be ommitted by CSOT #1644
Conversation
API Change ReportNo changes found! |
mongo/integration/csot_test.go
Outdated
|
||
// TODO(GODRIVER-2944): Remove this test once the "timeoutMode" option is | ||
// supported. | ||
mt.RunOpts("Find always sends manually-specified maxTimeMS", csotOpts, func(mt *mtest.T) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This test is being run with a client-level timeout of 10 seconds, set by previous subtests. The csotOpts should be reset before executing to test that the deprecated operation-level maxTimeMS value is being propagated to command message when omitting CSOT.
mt.RunOpts("Find always sends manually-specified maxTimeMS", csotOpts, func(mt *mtest.T) { | |
csotOpts = mtest.NewOptions().ClientOptions(options.Client()) | |
mt.RunOpts("Find always sends manually-specified maxTimeMS", csotOpts, func(mt *mtest.T) { |
Suggest adding the following function to test that a 5s timeout is being used:
assertMaxTimeMS := func(mt *mtest.T, command bson.Raw, expected int64) {
mt.Helper()
maxTimeVal := command.Lookup("maxTimeMS")
require.Greater(mt,
len(maxTimeVal.Value),
0,
"expected maxTimeMS BSON value to be non-empty")
require.Equal(mt,
maxTimeVal.Type,
bson.TypeInt64,
"expected maxTimeMS BSON value to be type Int64")
assert.Greater(mt,
maxTimeVal.Int64(),
int64(0),
"expected maxTimeMS value to be greater than 0")
assert.Equal(mt, expected, maxTimeVal.Int64())
}
Also suggest creating an additional test ensuring behavior defined in the Validation and Overrides section of the CSOT specifications:
When executing an operation, drivers MUST ignore any deprecated timeout options if timeoutMS is set on the operation or is inherited from the collection/database/client levels.
csotOpts = mtest.NewOptions().ClientOptions(options.Client().SetTimeout(15 * time.Second))
mt.RunOpts("Find sends client-level timeout over deprecated maxTimeMS", csotOpts, func(mt *mtest.T) {
ctx := context.Background()
// Manually set a maxTimeMS on the Find and assert that it's sent with
// the command, even when CSOT is enabled.
cursor, err := mt.Coll.Find(
ctx,
bson.D{},
options.Find().SetMaxTime(5*time.Second))
require.NoError(mt, err, "Find error")
err = cursor.Close(context.Background())
require.NoError(mt, err, "Cursor.Close error")
evt := getStartedEvent(mt, "find")
fmt.Println(evt)
//assertMaxTimeMSIsSet(mt, evt.Command)
assertMaxTimeMS(mt, evt.Command, 15000)
})
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the test matrix should look something like this:
- no client-level, operation-level, deprecated operation-level -> use DOL
- ~CL, ~OL, DOL -> DOL
- CL, OL, DOL -> DOL
- CL, ~OL, DOL -> CL
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The current test case is basically
CL, OL, DOL -> DOL
so setting timeoutMS
is intentional. However, the test doesn't cover the rest of the cases, which could be confusing (especially because the test description is actually incorrect, since a manually-set maxTimeMS
is ignored when a client-level timeout is set but no operation-level timeout is set).
I'll update the test to cover the additional cases.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I added test cases for the permutations you described.
mongo/integration/csot_test.go
Outdated
|
||
// TODO(GODRIVER-2944): Remove this test once the "timeoutMode" option is | ||
// supported. | ||
mt.RunOpts("Aggregate always sends manually-specified maxTimeMS", csotOpts, func(mt *mtest.T) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same considerations for "Find always sends manually-specified maxTimeMS" apply to the aggregate counterpart.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I added test cases for the permutations described in the other comment.
…ate if it would be ommitted by CSOT (#1644)
GODRIVER-3217
Summary
If
maxTimeMS
is specified on aFind
orAggregate
operation, always use it to setmaxTimeMS
on the command, even if CSOT is enabled.Background & Motivation
#1589 enabled sending an automatically calculated
maxTimeMS
with (almost) every command when CSOT is enabled. However, it doesn't sendmaxTimeMS
onFind
andAggregate
commands because it also sets a server-side lifetime on the cursor created by the command, which is surprising to many users. An unintended side effect of that change is thatmaxTimeMS
is ignored forFind
andAggregate
commands, meaning that there is no currently no way to setmaxTimeMS
on aFind
orAggregate
when CSOT is enabled. We want to allow users to setmaxTimeMS
if they need to.Note that this behavior will become irrelevant once GODRIVER-2944 is complete.