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
use stresstest.Stress
  • Loading branch information
chilagrow committed Jun 27, 2023
commit 733b14494898727e2001e60d1f30792eff3c56ab
64 changes: 22 additions & 42 deletions integration/commands_diagnostic_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,6 @@ package integration
import (
"net"
"net/url"
"runtime"
"sync"
"testing"

"github.com/stretchr/testify/assert"
Expand All @@ -31,6 +29,7 @@ import (
"github.com/FerretDB/FerretDB/integration/shareddata"
"github.com/FerretDB/FerretDB/internal/types"
"github.com/FerretDB/FerretDB/internal/util/must"
"github.com/FerretDB/FerretDB/internal/util/teststress"
"github.com/FerretDB/FerretDB/internal/util/testutil"
)

Expand Down Expand Up @@ -428,55 +427,36 @@ func TestCommandWhatsMyURIConnection(t *testing.T) {
databaseName := s.Collection.Database().Name()
collectionName := s.Collection.Name()

t.Run("SameClient", func(t *testing.T) {
t.Run("SameClientStress", func(t *testing.T) {
setup.SkipExceptMongoDB(t, "https://github.com/FerretDB/FerretDB/issues/2906")
AlekSi marked this conversation as resolved.
Show resolved Hide resolved

t.Parallel()

num := runtime.GOMAXPROCS(-1) * 10
ready := make(chan struct{}, num)
start := make(chan struct{})
ports := make(chan string, num)
ports := make(chan string, teststress.NumGoroutines)

var wg sync.WaitGroup
for i := 0; i < num; i++ {
wg.Add(1)
teststress.Stress(t, func(ready chan<- struct{}, start <-chan struct{}) {
ready <- struct{}{}
<-start

go func(i int) {
defer wg.Done()

ready <- struct{}{}

<-start

var res bson.D
err := collection1.Database().RunCommand(s.Ctx, bson.D{{"whatsmyuri", int32(1)}}).Decode(&res)
require.NoError(t, err)

doc := ConvertDocument(t, res)
v, _ := doc.Get("ok")
resOk, ok := v.(float64)
require.True(t, ok)
assert.Equal(t, float64(1), resOk)

v, _ = doc.Get("you")
you, ok := v.(string)
require.True(t, ok)

_, port, err := net.SplitHostPort(you)
require.NoError(t, err)
assert.NotEmpty(t, port)
ports <- port
}(i)
}
var res bson.D
err := collection1.Database().RunCommand(s.Ctx, bson.D{{"whatsmyuri", int32(1)}}).Decode(&res)
require.NoError(t, err)

for i := 0; i < num; i++ {
<-ready
}
doc := ConvertDocument(t, res)
v, _ := doc.Get("ok")
resOk, ok := v.(float64)
require.True(t, ok)
assert.Equal(t, float64(1), resOk)

close(start)
v, _ = doc.Get("you")
you, ok := v.(string)
require.True(t, ok)

wg.Wait()
_, port, err := net.SplitHostPort(you)
require.NoError(t, err)
assert.NotEmpty(t, port)
ports <- port
})

close(ports)

Expand Down
11 changes: 6 additions & 5 deletions internal/util/teststress/stress.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,22 +23,23 @@ import (
"testing"
)

// NumGoroutines is the total count of goroutines created in Stress function.
var NumGoroutines = runtime.GOMAXPROCS(-1) * 10

// Stress runs function f in multiple goroutines.
//
// Function f should do a needed setup, send a message to ready channel when it is ready to start,
// wait for start channel to be closed, and then do the actual work.
func Stress(tb testing.TB, f func(ready chan<- struct{}, start <-chan struct{})) {
tb.Helper()

n := runtime.GOMAXPROCS(-1) * 10

// do a bit more work to reduce a chance that one goroutine would finish
// before the other one is still being created
var wg sync.WaitGroup
readyCh := make(chan struct{}, n)
readyCh := make(chan struct{}, NumGoroutines)
startCh := make(chan struct{})

for i := 0; i < n; i++ {
for i := 0; i < NumGoroutines; i++ {
wg.Add(1)

go func() {
Expand All @@ -48,7 +49,7 @@ func Stress(tb testing.TB, f func(ready chan<- struct{}, start <-chan struct{}))
}()
}

for i := 0; i < n; i++ {
for i := 0; i < NumGoroutines; i++ {
<-readyCh
}

Expand Down