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

Test getMore integration test using one connection pool #2878

Merged
merged 35 commits into from
Jun 29, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
35 commits
Select commit Hold shift + click to select a range
913cb04
set pool size in client
chilagrow Jun 21, 2023
f916843
expose ClientOption to setup
chilagrow Jun 21, 2023
3e00842
rename and comment update
chilagrow Jun 23, 2023
04c75a6
use url.Values
chilagrow Jun 23, 2023
40a511f
tidy up
chilagrow Jun 26, 2023
2f1b735
add same client and different client connection tests
chilagrow Jun 26, 2023
5d0a147
update error message for same client tests
chilagrow Jun 26, 2023
9de04ca
skip test for feature not supported by FerretDB
chilagrow Jun 26, 2023
734d5bf
comment update
chilagrow Jun 26, 2023
962ed96
run subtests in parallel
chilagrow Jun 26, 2023
0a74652
merge
chilagrow Jun 27, 2023
b0e8761
test setup handles merging url with extra url.Values option
chilagrow Jun 27, 2023
733b144
use stresstest.Stress
chilagrow Jun 27, 2023
e6a30e5
add batchSize test for find and getMore
chilagrow Jun 27, 2023
c6811fe
add getMore test for using different client
chilagrow Jun 27, 2023
1b450c7
update test
chilagrow Jun 27, 2023
a21acef
Merge branch 'main' into issue-1807-analysis
chilagrow Jun 27, 2023
405e8c9
update commnet
chilagrow Jun 27, 2023
805fcb2
cleanup
chilagrow Jun 27, 2023
9e6b8e9
do not run session related tests in parallel
chilagrow Jun 27, 2023
1e1f975
refactor
chilagrow Jun 27, 2023
fe31dfd
fix
chilagrow Jun 27, 2023
baf6065
Merge branch 'main' into issue-1807-analysis
chilagrow Jun 27, 2023
aae64c8
separate mongodburi and setup listener from extra options
chilagrow Jun 28, 2023
a22d37c
refactoring func name
chilagrow Jun 28, 2023
1a65aac
update comments and rename
chilagrow Jun 28, 2023
0e7adb8
cleanup
chilagrow Jun 28, 2023
bb965f5
Merge branch 'main' into issue-1807-analysis
chilagrow Jun 28, 2023
a9ea919
Merge branch 'main' into issue-1807-analysis
AlekSi Jun 28, 2023
c2397d2
fix new linter
chilagrow Jun 28, 2023
d7d3b8e
Merge branch 'issue-1807-analysis' of github.com:chilagrow/FerretDB i…
chilagrow Jun 28, 2023
02f1d08
Merge branch 'main' into issue-1807-analysis
AlekSi Jun 28, 2023
d5df4e0
Tweak comment
AlekSi Jun 28, 2023
17db130
Simplify
AlekSi Jun 28, 2023
676af8a
Refactor
AlekSi Jun 28, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
add getMore test for using different client
  • Loading branch information
chilagrow committed Jun 27, 2023
commit c6811fe723a4cfefd7e650aad245c14363d34e27
2 changes: 0 additions & 2 deletions integration/commands_diagnostic_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -428,8 +428,6 @@ func TestCommandWhatsMyURIConnection(t *testing.T) {
collectionName := s.Collection.Name()

t.Run("SameClientStress", func(t *testing.T) {
setup.SkipExceptMongoDB(t, "https://github.com/FerretDB/FerretDB/issues/2906")

t.Parallel()

ports := make(chan string, teststress.NumGoroutines)
Expand Down
126 changes: 119 additions & 7 deletions integration/query_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ import (

"github.com/FerretDB/FerretDB/integration/setup"
"github.com/FerretDB/FerretDB/integration/shareddata"
"github.com/FerretDB/FerretDB/internal/util/teststress"
)

func TestQueryBadFindType(t *testing.T) {
Expand Down Expand Up @@ -958,15 +959,13 @@ func TestQueryBatchSize(t *testing.T) {
func TestQueryCommandGetMore(t *testing.T) {
t.Parallel()

q := url.Values{}

// set 1 to ensure only one pool exists duration of the test,
// set minPoolSize and maxPoolSize 1 to ensure only one pool exists duration of the test,
// which forces a client to use a single connection pool
q.Set("maxPoolSize", "1")
q.Set("minPoolSize", "1")

s := setup.SetupWithOpts(t, &setup.SetupOpts{
ExtraOptions: q,
ExtraOptions: url.Values{
"minPoolSize": []string{"1"},
"maxPoolSize": []string{"1"},
},
})

ctx, collection := s.Ctx, s.Collection
Expand Down Expand Up @@ -1316,3 +1315,116 @@ func TestQueryCommandGetMore(t *testing.T) {
})
}
}

// TestQueryCommandGetMoreConnection tests that a client uses the same connection for
// getMore command run by the client, and different clients use different connection.
func TestQueryCommandGetMoreConnection(t *testing.T) {
t.Parallel()

// set minPoolSize and maxPoolSize 1 to ensure only one pool exists duration of the test,
// which forces a client to use a single connection pool
s := setup.SetupWithOpts(t, &setup.SetupOpts{
ExtraOptions: url.Values{
"minPoolSize": []string{"1"},
"maxPoolSize": []string{"1"},
},
})

collection1 := s.Collection
databaseName := s.Collection.Database().Name()
collectionName := s.Collection.Name()

docs := generateDocuments(0, 110)
_, err := collection1.InsertMany(s.Ctx, docs)
require.NoError(t, err)

t.Run("SameClientStress", func(t *testing.T) {
t.Parallel()

teststress.Stress(t, func(ready chan<- struct{}, start <-chan struct{}) {
ready <- struct{}{}
<-start

var res bson.D
err := collection1.Database().RunCommand(s.Ctx,
bson.D{
{"find", collection1.Name()},
{"batchSize", 2},
}).Decode(&res)
require.NoError(t, err)

v, ok := res.Map()["cursor"]
require.True(t, ok)

cursor, ok := v.(bson.D)
require.True(t, ok)

cursorID := cursor.Map()["id"]
assert.NotNil(t, cursorID)

err = collection1.Database().RunCommand(s.Ctx, bson.D{
{"getMore", cursorID},
{"collection", collection1.Name()},
}).Decode(&res)
require.NoError(t, err)
})
})

t.Run("DifferentClient", func(t *testing.T) {
// error returned from using different clients are session related error,
// currently FerretDB does not return an error
setup.SkipExceptMongoDB(t, "https://github.com/FerretDB/FerretDB/issues/153")

t.Parallel()
AlekSi marked this conversation as resolved.
Show resolved Hide resolved

u, err := url.Parse(s.MongoDBURI)
require.NoError(t, err)

q2 := u.Query()
q2.Set("maxPoolSize", "1")
q2.Set("minPoolSize", "1")
u.RawQuery = q2.Encode()

client2, err := mongo.Connect(s.Ctx, options.Client().ApplyURI(u.String()))
require.NoError(t, err)

defer client2.Disconnect(s.Ctx)

collection2 := client2.Database(databaseName).Collection(collectionName)

var res bson.D
err = collection1.Database().RunCommand(s.Ctx,
bson.D{
{"find", collection1.Name()},
{"batchSize", 2},
}).Decode(&res)
require.NoError(t, err)

v, ok := res.Map()["cursor"]
require.True(t, ok)

cursor, ok := v.(bson.D)
require.True(t, ok)

cursorID := cursor.Map()["id"]
assert.NotNil(t, cursorID)

err = collection2.Database().RunCommand(s.Ctx, bson.D{
{"getMore", cursorID},
{"collection", collection2.Name()},
}).Decode(&res)

// use AssertEqualCommandError because message cannot be compared as it contains specific session ID
AssertMatchesCommandError(
t,
mongo.CommandError{
Code: 50738,
Name: "Location50738",
Message: "Cannot run getMore on cursor 5720627396082469624, which was created in session " +
"95326129-ff9c-48a4-9060-464b4ea3ee06 - 47DEQpj8HBSa+/TImW+5JC\neuQeRkm5NMpJWZG3hSuFU= - - , " +
"in session 9e8902e9-338c-4156-9fd8-50e5d62ac992 - 47DEQpj8HBSa+/TImW+5JCeuQeRkm5NMpJWZG3hSuFU= - - ",
},
err,
)
})
}