diff --git a/CHANGELOG.md b/CHANGELOG.md index fbec3f1b7..82d45096a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -22,6 +22,7 @@ Versioning](http://semver.org/spec/v2.0.0.html) except to the first release. - Support `crud.schema` request (#336) - Support `IPROTO_WATCH_ONCE` request type for Tarantool version >= 3.0.0-alpha1 (#337) +- Support `yield_every` option for crud select requests (#???) ### Changed diff --git a/crud/count.go b/crud/count.go index e4c163249..9deb1e44c 100644 --- a/crud/count.go +++ b/crud/count.go @@ -29,6 +29,7 @@ type CountOpts struct { // load balancing policy. Balance OptBool // YieldEvery describes number of tuples processed to yield after. + // Should be positive. YieldEvery OptUint // BucketId is a bucket ID. BucketId OptUint diff --git a/crud/options.go b/crud/options.go index eec3fc0db..fa5dca2c9 100644 --- a/crud/options.go +++ b/crud/options.go @@ -23,6 +23,7 @@ const ( batchSizeOptName = "batch_size" fetchLatestMetadataOptName = "fetch_latest_metadata" noreturnOptName = "noreturn" + yieldEvery = "yield_every" ) // OptUint is an optional uint. diff --git a/crud/select.go b/crud/select.go index 198f74bae..24dbd0cb0 100644 --- a/crud/select.go +++ b/crud/select.go @@ -46,17 +46,21 @@ type SelectOpts struct { // the latest migration of the data format. Performance overhead is up to 15%. // Disabled by default. FetchLatestMetadata OptBool + // YieldEvery describes number of tuples processed to yield after. + // Should be positive. + YieldEvery OptUint } // EncodeMsgpack provides custom msgpack encoder. func (opts SelectOpts) EncodeMsgpack(enc *msgpack.Encoder) error { - const optsCnt = 13 + const optsCnt = 14 names := [optsCnt]string{timeoutOptName, vshardRouterOptName, fieldsOptName, bucketIdOptName, modeOptName, preferReplicaOptName, balanceOptName, firstOptName, afterOptName, batchSizeOptName, - forceMapCallOptName, fullscanOptName, fetchLatestMetadataOptName} + forceMapCallOptName, fullscanOptName, fetchLatestMetadataOptName, + yieldEveryOptName} values := [optsCnt]interface{}{} exists := [optsCnt]bool{} values[0], exists[0] = opts.Timeout.Get() @@ -72,6 +76,7 @@ func (opts SelectOpts) EncodeMsgpack(enc *msgpack.Encoder) error { values[10], exists[10] = opts.ForceMapCall.Get() values[11], exists[11] = opts.Fullscan.Get() values[12], exists[12] = opts.FetchLatestMetadata.Get() + values[13], exists[13] = opts.YieldEvery.Get() return encodeOptions(enc, names[:], values[:], exists[:]) } diff --git a/crud/tarantool_test.go b/crud/tarantool_test.go index 511980bd9..399b0d48f 100644 --- a/crud/tarantool_test.go +++ b/crud/tarantool_test.go @@ -1333,6 +1333,40 @@ func TestUnitEmptySchema(t *testing.T) { require.Equal(t, result.Value, crud.Schema{}, "empty schema expected") } +var testStorageYieldCases = []struct { + name string + req tarantool.Request +}{ + { + "Count", + crud.MakeCountRequest(spaceName). + Opts(crud.CountOpts{ + YieldEvery: crud.MakeOptUint(500), + }), + }, + { + "Select", + crud.MakeSelectRequest(spaceName). + Opts(crud.SelectOpts{ + YieldEvery: crud.MakeOptUint(500), + }), + }, +} + +func TestYieldEveryOption(t *testing.T) { + conn := connect(t) + defer conn.Close() + + for _, testCase := range testStorageYieldCases { + t.Run(testCase.name, func(t *testing.T) { + _, err := conn.Do(testCase.req).Get() + if err != nil { + t.Fatalf("Failed to Do CRUD request: %s", err) + } + }) + } +} + // runTestMain is a body of TestMain function // (see https://pkg.go.dev/testing#hdr-Main). // Using defer + os.Exit is not works so TestMain body