Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitaly.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJustin Tobler <jtobler@gitlab.com>2022-08-26 00:15:35 +0300
committerJustin Tobler <jtobler@gitlab.com>2022-08-26 00:15:35 +0300
commitba174830d2869038ba7b6b676f634be89fc3ace2 (patch)
tree50136048bb4a1d64ad9ad707b9e99920351be707
parent2db83e86b85bd1323c90fd5e94b01c23e9923583 (diff)
parent6f0f7ce3b2f22a96d683772199f488e11d115cbc (diff)
Merge branch 'ps-flaky-server-factory' into 'master'
Fix flaky tests of the TestGitalyServerFactory test suite Closes #3916 See merge request gitlab-org/gitaly!4841
-rw-r--r--internal/gitaly/server/server_factory_test.go38
1 files changed, 19 insertions, 19 deletions
diff --git a/internal/gitaly/server/server_factory_test.go b/internal/gitaly/server/server_factory_test.go
index 5959a6910..9a181089d 100644
--- a/internal/gitaly/server/server_factory_test.go
+++ b/internal/gitaly/server/server_factory_test.go
@@ -20,9 +20,9 @@ import (
"gitlab.com/gitlab-org/gitaly/v15/internal/bootstrap/starter"
"gitlab.com/gitlab-org/gitaly/v15/internal/cache"
"gitlab.com/gitlab-org/gitaly/v15/internal/gitaly/config"
- "gitlab.com/gitlab-org/gitaly/v15/internal/middleware/limithandler"
"gitlab.com/gitlab-org/gitaly/v15/internal/testhelper"
"gitlab.com/gitlab-org/gitaly/v15/internal/testhelper/testcfg"
+ "golang.org/x/sync/errgroup"
"google.golang.org/grpc"
"google.golang.org/grpc/codes"
"google.golang.org/grpc/credentials"
@@ -34,20 +34,21 @@ import (
func TestGitalyServerFactory(t *testing.T) {
ctx := testhelper.Context(t)
+ grp, ctx := errgroup.WithContext(ctx)
+ t.Cleanup(func() { assert.NoError(t, grp.Wait()) })
checkHealth := func(t *testing.T, sf *GitalyServerFactory, schema, addr string) healthpb.HealthClient {
t.Helper()
var cc *grpc.ClientConn
if schema == starter.TLS {
- listener, err := net.Listen(starter.TCP, addr)
- require.NoError(t, err)
- t.Cleanup(func() { listener.Close() })
-
srv, err := sf.CreateExternal(true)
require.NoError(t, err)
healthpb.RegisterHealthServer(srv, health.NewServer())
- go srv.Serve(listener)
+
+ listener, err := net.Listen(starter.TCP, addr)
+ require.NoError(t, err)
+ grp.Go(func() error { return srv.Serve(listener) })
certPool, err := x509.SystemCertPool()
require.NoError(t, err)
@@ -63,14 +64,13 @@ func TestGitalyServerFactory(t *testing.T) {
cc, err = grpc.DialContext(ctx, listener.Addr().String(), grpc.WithTransportCredentials(creds))
require.NoError(t, err)
} else {
- listener, err := net.Listen(schema, addr)
- require.NoError(t, err)
- t.Cleanup(func() { listener.Close() })
-
srv, err := sf.CreateExternal(false)
require.NoError(t, err)
healthpb.RegisterHealthServer(srv, health.NewServer())
- go srv.Serve(listener)
+
+ listener, err := net.Listen(schema, addr)
+ require.NoError(t, err)
+ grp.Go(func() error { return srv.Serve(listener) })
endpoint, err := starter.ComposeEndpoint(schema, listener.Addr().String())
require.NoError(t, err)
@@ -78,11 +78,9 @@ func TestGitalyServerFactory(t *testing.T) {
cc, err = client.Dial(endpoint, nil)
require.NoError(t, err)
}
-
- t.Cleanup(func() { cc.Close() })
+ t.Cleanup(func() { assert.NoError(t, cc.Close()) })
healthClient := healthpb.NewHealthClient(cc)
-
resp, err := healthClient.Check(ctx, &healthpb.HealthCheckRequest{})
require.NoError(t, err)
require.Equal(t, healthpb.HealthCheckResponse_SERVING, resp.Status)
@@ -96,8 +94,9 @@ func TestGitalyServerFactory(t *testing.T) {
testhelper.NewDiscardingLogEntry(t),
backchannel.NewRegistry(),
cache.New(cfg, config.NewLocator(cfg)),
- []*limithandler.LimiterMiddleware{limithandler.New(cfg, limithandler.LimitConcurrencyByRepo, limithandler.WithConcurrencyLimiters)},
+ nil,
)
+ t.Cleanup(sf.Stop)
checkHealth(t, sf, starter.TCP, "localhost:0")
})
@@ -115,7 +114,7 @@ func TestGitalyServerFactory(t *testing.T) {
testhelper.NewDiscardingLogEntry(t),
backchannel.NewRegistry(),
cache.New(cfg, config.NewLocator(cfg)),
- []*limithandler.LimiterMiddleware{limithandler.New(cfg, limithandler.LimitConcurrencyByRepo, limithandler.WithConcurrencyLimiters)},
+ nil,
)
t.Cleanup(sf.Stop)
@@ -129,7 +128,7 @@ func TestGitalyServerFactory(t *testing.T) {
testhelper.NewDiscardingLogEntry(t),
backchannel.NewRegistry(),
cache.New(cfg, config.NewLocator(cfg)),
- []*limithandler.LimiterMiddleware{limithandler.New(cfg, limithandler.LimitConcurrencyByRepo, limithandler.WithConcurrencyLimiters)},
+ nil,
)
t.Cleanup(sf.Stop)
@@ -159,8 +158,9 @@ func TestGitalyServerFactory(t *testing.T) {
logger.WithContext(ctx),
backchannel.NewRegistry(),
cache.New(cfg, config.NewLocator(cfg)),
- []*limithandler.LimiterMiddleware{limithandler.New(cfg, limithandler.LimitConcurrencyByRepo, limithandler.WithConcurrencyLimiters)},
+ nil,
)
+ t.Cleanup(sf.Stop)
checkHealth(t, sf, starter.TCP, "localhost:0")
@@ -193,7 +193,7 @@ func TestGitalyServerFactory_closeOrder(t *testing.T) {
testhelper.NewDiscardingLogEntry(t),
backchannel.NewRegistry(),
cache.New(cfg, config.NewLocator(cfg)),
- []*limithandler.LimiterMiddleware{limithandler.New(cfg, limithandler.LimitConcurrencyByRepo, limithandler.WithConcurrencyLimiters)},
+ nil,
)
defer sf.Stop()