Skip to content

Commit

Permalink
add more locks
Browse files Browse the repository at this point in the history
Signed-off-by: NikitaSkrynnik <nikita.skrynnik@xored.com>
  • Loading branch information
NikitaSkrynnik committed Sep 24, 2024
1 parent 876866f commit 7f08d07
Show file tree
Hide file tree
Showing 3 changed files with 15 additions and 9 deletions.
2 changes: 1 addition & 1 deletion pkg/networkservice/chains/nsmgr/heal_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -819,7 +819,7 @@ func TestNSMGR_RefreshFailed_DataPlaneBroken(t *testing.T) {
}

// This test shows that healing successfully restores the connection if one of the components is killed during the Request
func TestNSMGR_RefreshFailed_ControlPlaneBrokn(t *testing.T) {
func TestNSMGR_RefreshFailed_ControlPlaneBroken(t *testing.T) {
t.Cleanup(func() { goleak.VerifyNone(t) })

ctx, cancel := context.WithTimeout(context.Background(), timeout)
Expand Down
20 changes: 13 additions & 7 deletions pkg/networkservice/common/dial/dialer.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,10 +31,9 @@ import (
)

type dialer struct {
ctx context.Context
cleanupContext context.Context
clientURL *url.URL
cleanupCancel context.CancelFunc
ctx context.Context
clientURL *url.URL
cleanupCancel context.CancelFunc
*grpc.ClientConn
dialOptions []grpc.DialOption
dialTimeout time.Duration
Expand Down Expand Up @@ -70,28 +69,35 @@ func (di *dialer) Dial(ctx context.Context, clientURL *url.URL) error {
}

// Dial
di.mu.Lock()
target := grpcutils.URLToTarget(di.clientURL)
di.mu.Unlock()

cc, err := grpc.DialContext(dialCtx, target, di.dialOptions...)
if err != nil {
if cc != nil {
_ = cc.Close()
}
return errors.Wrapf(err, "failed to dial %s", target)
}
di.mu.Lock()
di.ClientConn = cc

di.cleanupContext, di.cleanupCancel = context.WithCancel(di.ctx)
var cleanupContext context.Context
cleanupContext, di.cleanupCancel = context.WithCancel(di.ctx)
di.mu.Unlock()

go func(cleanupContext context.Context, cc *grpc.ClientConn) {
<-cleanupContext.Done()
_ = cc.Close()
}(di.cleanupContext, cc)
}(cleanupContext, cc)
return nil
}

func (di *dialer) Close() error {
if di != nil && di.cleanupCancel != nil {
di.mu.Lock()
di.cleanupCancel()
di.mu.Unlock()
runtime.Gosched()
}
return nil
Expand Down
2 changes: 1 addition & 1 deletion pkg/networkservice/common/discoverforwarder/server.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
// Copyright (c) 2021-2022 Doc.ai and/or its affiliates.
//
// Copyright (c) 2023 Cisco and/or its affiliates.
// Copyright (c) 2023-2024 Cisco and/or its affiliates.
//
// SPDX-License-Identifier: Apache-2.0
//
Expand Down

0 comments on commit 7f08d07

Please sign in to comment.