From 95f018a3de7220f7b1cff236e16454ce664c9f1d Mon Sep 17 00:00:00 2001 From: Timofey Koolin Date: Fri, 24 Nov 2023 15:51:21 +0300 Subject: [PATCH] separate lifetime for option context from connection context --- CHANGELOG.md | 2 ++ driver.go | 19 ++++++++++++++++++- 2 files changed, 20 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 558bf6b31..66371f0ff 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,5 @@ +* Context for call options now have same lifetime as driver (previous - same lifetime as context for call Open function). + ## v3.54.2 * Added context to some internal methods for better tracing * Added `trace.FunctionID` helper and `FunctionID` field to trace start info's diff --git a/driver.go b/driver.go index 69c96873a..eea9687cc 100644 --- a/driver.go +++ b/driver.go @@ -30,6 +30,7 @@ import ( internalTable "github.com/ydb-platform/ydb-go-sdk/v3/internal/table" tableConfig "github.com/ydb-platform/ydb-go-sdk/v3/internal/table/config" "github.com/ydb-platform/ydb-go-sdk/v3/internal/topic/topicclientinternal" + "github.com/ydb-platform/ydb-go-sdk/v3/internal/xcontext" "github.com/ydb-platform/ydb-go-sdk/v3/internal/xerrors" "github.com/ydb-platform/ydb-go-sdk/v3/internal/xsql" "github.com/ydb-platform/ydb-go-sdk/v3/internal/xsync" @@ -47,6 +48,9 @@ var _ Connection = (*Driver)(nil) // Driver type provide access to YDB service clients type Driver struct { //nolint:maligned + ctx context.Context // cancel while Driver.Close called. + ctxCancel context.CancelFunc + userInfo *dsn.UserInfo logger log.Logger @@ -106,10 +110,13 @@ func (d *Driver) Close(ctx context.Context) (finalErr error) { defer func() { onDone(finalErr) }() + d.ctxCancel() d.mtx.Lock() defer d.mtx.Unlock() + d.ctxCancel() + defer func() { for _, f := range d.onClose { f(d) @@ -268,9 +275,19 @@ func New(ctx context.Context, opts ...Option) (_ *Driver, err error) { } func newConnectionFromOptions(ctx context.Context, opts ...Option) (_ *Driver, err error) { + ctx, driverCtxCancel := xcontext.WithCancel(xcontext.WithoutDeadline(ctx)) + defer func() { + if err != nil { + driverCtxCancel() + } + }() + d := &Driver{ - children: make(map[uint64]*Driver), + children: make(map[uint64]*Driver), + ctx: ctx, + ctxCancel: driverCtxCancel, } + if caFile, has := os.LookupEnv("YDB_SSL_ROOT_CERTIFICATES_FILE"); has { d.opts = append(d.opts, WithCertificatesFromFile(caFile),