Skip to content

Commit

Permalink
CBG-3271 remove persistent rosmar buckets
Browse files Browse the repository at this point in the history
- rosmar now supports persisting in memory buckets, so keep the buckets
  in memory until the buckets are closed. This eliminates NoCloseClone
  in many cases. Another PR might be able to remove even more of these.
- this is prep for being able to run a bootstrap connection.
  • Loading branch information
torcolvin committed Nov 8, 2023
1 parent 1bef056 commit 5cea24b
Show file tree
Hide file tree
Showing 18 changed files with 59 additions and 137 deletions.
4 changes: 2 additions & 2 deletions base/leaky_bucket.go
Original file line number Diff line number Diff line change
Expand Up @@ -58,9 +58,9 @@ func (b *LeakyBucket) SetIgnoreClose(value bool) {
b.config.IgnoreClose = value
}

func (b *LeakyBucket) CloseAndDelete() error {
func (b *LeakyBucket) CloseAndDelete(ctx context.Context) error {
if bucket, ok := b.bucket.(sgbucket.DeleteableStore); ok {
return bucket.CloseAndDelete()
return bucket.CloseAndDelete(ctx)
}
return nil
}
Expand Down
28 changes: 6 additions & 22 deletions base/main_test_bucket_pool.go
Original file line number Diff line number Diff line change
Expand Up @@ -198,29 +198,17 @@ func (tbp *TestBucketPool) GetWalrusTestBucket(t testing.TB, url string) (b Buck
require.NoError(t, err)

var walrusBucket *rosmar.Bucket
var typeName string
const typeName = "rosmar"
bucketName := tbpBucketNamePrefix + "rosmar_" + id
if url == "walrus:" || url == rosmar.InMemoryURL {
walrusBucket, err = rosmar.OpenBucket(url, rosmar.CreateOrOpen)
if err == nil {
err := walrusBucket.SetName(bucketName)
if err != nil {
tbp.Fatalf(testCtx, "Could not set name %s for rosmar bucket: %s", bucketName, err)
}
}
walrusBucket, err = rosmar.OpenBucket(url, bucketName, rosmar.CreateOrOpen)
} else {
walrusBucket, err = rosmar.OpenBucketIn(url, bucketName, rosmar.CreateOrOpen)
}
typeName = "rosmar"
if err != nil {
tbp.Fatalf(testCtx, "couldn't get %s bucket from <%s>: %v", typeName, url, err)
}

err = walrusBucket.SetName(bucketName)
if err != nil {
tbp.Fatalf(testCtx, "Could not set name %s for rosmar bucket: %s", bucketName, err)
}

// Wrap Walrus buckets with a leaky bucket to support vbucket IDs on feed.
b = &LeakyBucket{bucket: walrusBucket, config: &LeakyBucketConfig{TapFeedVbuckets: true}}

Expand Down Expand Up @@ -258,14 +246,10 @@ func (tbp *TestBucketPool) GetWalrusTestBucket(t testing.TB, url string) (b Buck
atomic.AddInt32(&tbp.stats.NumBucketsClosed, 1)
atomic.AddInt64(&tbp.stats.TotalInuseBucketNano, time.Since(openedStart).Nanoseconds())
tbp.markBucketClosed(t, b)
if url == kTestWalrusURL {
b.Close(ctx)
} else {
// Persisted buckets should call close and delete
closeErr := walrusBucket.CloseAndDelete()
if closeErr != nil {
tbp.Logf(ctx, "Unexpected error closing persistent %s bucket: %v", typeName, closeErr)
}
// Persisted buckets should call close and delete
closeErr := walrusBucket.CloseAndDelete(ctx)
if closeErr != nil {
tbp.Logf(ctx, "Unexpected error closing persistent %s bucket: %v", typeName, closeErr)
}

}
Expand Down
29 changes: 0 additions & 29 deletions base/util_testing.go
Original file line number Diff line number Diff line change
Expand Up @@ -108,12 +108,6 @@ func GetTestBucket(t testing.TB) *TestBucket {
return getTestBucket(t, false)
}

// GetTestBucket returns a test bucket from a pool. If running with walrus buckets, will persist bucket data
// across bucket close.
func GetPersistentTestBucket(t testing.TB) *TestBucket {
return getTestBucket(t, true)
}

// getTestBucket returns a bucket from the bucket pool. Persistent flag determines behaviour for walrus
// buckets only - Couchbase bucket behaviour is defined by the bucket pool readier/init.
func getTestBucket(t testing.TB, persistent bool) *TestBucket {
Expand Down Expand Up @@ -210,29 +204,6 @@ func rosmarUriFromPath(path string) string {
return uri + strings.ReplaceAll(path, `\`, `/`)
}

// Gets a Walrus bucket which will be persisted to a temporary directory
// Returns both the test bucket which is persisted and a function which can be used to remove the created temporary
// directory once the test has finished with it.
func GetPersistentWalrusBucket(t testing.TB) (*TestBucket, func()) {
tempDir, err := os.MkdirTemp("", "walrustemp")
require.NoError(t, err)

bucket, spec, closeFn := GTestBucketPool.GetWalrusTestBucket(t, rosmarUriFromPath(tempDir))

// Return this separate to closeFn as we want to avoid this being removed on database close (/_offline handling)
removeFileFunc := func() {
err := os.RemoveAll(tempDir)
require.NoError(t, err)
}

return &TestBucket{
Bucket: bucket,
BucketSpec: spec,
closeFn: closeFn,
t: t,
}, removeFileFunc
}

// Should Sync Gateway use XATTRS functionality when running unit tests?
func TestUseXattrs() bool {
useXattrs, isSet := os.LookupEnv(TestEnvSyncGatewayUseXattrs)
Expand Down
4 changes: 2 additions & 2 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -13,10 +13,10 @@ require (
github.com/couchbase/gocbcore/v10 v10.2.8
github.com/couchbase/gomemcached v0.2.1
github.com/couchbase/goutils v0.1.2
github.com/couchbase/sg-bucket v0.0.0-20231003103030-627c70e18148
github.com/couchbase/sg-bucket v0.0.0-20231108134134-545ec7bf1a9e
github.com/couchbaselabs/go-fleecedelta v0.0.0-20220909152808-6d09efa7a338
github.com/couchbaselabs/gocbconnstr v1.0.5
github.com/couchbaselabs/rosmar v0.0.0-20231003104919-6d4a3e8a6db6
github.com/couchbaselabs/rosmar v0.0.0-20231108144220-c0c6c76bb267
github.com/elastic/gosigar v0.14.2
github.com/felixge/fgprof v0.9.3
github.com/google/uuid v1.3.1
Expand Down
11 changes: 7 additions & 4 deletions go.sum
Original file line number Diff line number Diff line change
@@ -1,8 +1,11 @@
dario.cat/mergo v1.0.0 h1:AGCNq9Evsj31mOgNPcLyXc+4PNABt905YmuqPYYpBWk=
dario.cat/mergo v1.0.0/go.mod h1:uNxQE+84aUszobStD9th8a29P2fMDhsBdgRYvZOxGmk=
github.com/Azure/azure-sdk-for-go/sdk/azcore v1.6.1 h1:SEy2xmstIphdPwNBUi7uhvjyjhVKISfwjfOJmuy7kg4=
github.com/Azure/azure-sdk-for-go/sdk/azcore v1.6.1/go.mod h1:bjGvMhVMb+EEm3VRNQawDMUyMMjo+S5ewNjflkep/0Q=
github.com/Azure/azure-sdk-for-go/sdk/internal v1.3.0 h1:sXr+ck84g/ZlZUOZiNELInmMgOsuGwdjjVkEIde0OtY=
github.com/Azure/azure-sdk-for-go/sdk/internal v1.3.0/go.mod h1:okt5dMMTOFjX/aovMlrjvvXoPMBVSPzk9185BT0+eZM=
github.com/Azure/azure-sdk-for-go/sdk/storage/azblob v1.0.0 h1:u/LLAOFgsMv7HmNL4Qufg58y+qElGOt5qv0z1mURkRY=
github.com/Azure/azure-sdk-for-go/sdk/storage/azblob v1.0.0/go.mod h1:2e8rMJtl2+2j+HXbTBwnyGpm5Nou7KhvSfxOq8JpTag=
github.com/BurntSushi/toml v1.3.2 h1:o7IhLm0Msx3BaB+n3Ag7L8EVlByGnpq14C4YWiu/gL8=
github.com/BurntSushi/toml v1.3.2/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ=
github.com/aws/aws-sdk-go v1.44.299 h1:HVD9lU4CAFHGxleMJp95FV/sRhtg7P4miHD1v88JAQk=
Expand Down Expand Up @@ -38,8 +41,6 @@ github.com/couchbase/gomemcached v0.2.1 h1:lDONROGbklo8pOt4Sr4eV436PVEaKDr3o9gUl
github.com/couchbase/gomemcached v0.2.1/go.mod h1:mxliKQxOv84gQ0bJWbI+w9Wxdpt9HjDvgW9MjCym5Vo=
github.com/couchbase/goutils v0.1.2 h1:gWr8B6XNWPIhfalHNog3qQKfGiYyh4K4VhO3P2o9BCs=
github.com/couchbase/goutils v0.1.2/go.mod h1:h89Ek/tiOxxqjz30nPPlwZdQbdB8BwgnuBxeoUe/ViE=
github.com/couchbase/sg-bucket v0.0.0-20231003103030-627c70e18148 h1:9E3u0yA+be219iLLOjuYgagOfM7UqtZ0YIhMXysJVKs=
github.com/couchbase/sg-bucket v0.0.0-20231003103030-627c70e18148/go.mod h1:hy6J0RXx/Ry+5EiI8VVMetsVfBXQq5/djQLbvfRau0k=
github.com/couchbase/tools-common/cloud v1.0.0 h1:SQZIccXoedbrThehc/r9BJbpi/JhwJ8X00PDjZ2gEBE=
github.com/couchbase/tools-common/cloud v1.0.0/go.mod h1:6KVlRpbcnDWrvickUJ+xpqCWx1vgYYlEli/zL4xmZAg=
github.com/couchbase/tools-common/fs v1.0.0 h1:HFA4xCF/r3BtZShFJUxzVvGuXtDkqGnaPzYJP3Kp1mw=
Expand All @@ -57,8 +58,6 @@ github.com/couchbaselabs/gocaves/client v0.0.0-20230404095311-05e3ba4f0259 h1:2T
github.com/couchbaselabs/gocaves/client v0.0.0-20230404095311-05e3ba4f0259/go.mod h1:AVekAZwIY2stsJOMWLAS/0uA/+qdp7pjO8EHnl61QkY=
github.com/couchbaselabs/gocbconnstr v1.0.5 h1:e0JokB5qbcz7rfnxEhNRTKz8q1svoRvDoZihsiwNigA=
github.com/couchbaselabs/gocbconnstr v1.0.5/go.mod h1:KV3fnIKMi8/AzX0O9zOrO9rofEqrRF1d2rG7qqjxC7o=
github.com/couchbaselabs/rosmar v0.0.0-20231003104919-6d4a3e8a6db6 h1:TeqaJ0zV0omrnvQfw4DF6o+UQQbFdBNPJVod1Y7ovQo=
github.com/couchbaselabs/rosmar v0.0.0-20231003104919-6d4a3e8a6db6/go.mod h1:+HMmQTjaINo51eSZFeCKreXYSIu6jbIp+EV9keoKl3E=
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
Expand Down Expand Up @@ -97,6 +96,7 @@ github.com/golang/snappy v0.0.4/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEW
github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
github.com/google/go-cmp v0.5.9 h1:O2Tfq5qg4qc4AmwVlvv0oLiVAGB7enBSJ2x2DqQFi38=
github.com/google/go-cmp v0.5.9/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY=
github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
github.com/google/pprof v0.0.0-20211214055906-6f57359322fd h1:1FjCyPC+syAzJ5/2S8fqdZK1R22vvA0J7JZKcuOIQ7Y=
github.com/google/pprof v0.0.0-20211214055906-6f57359322fd/go.mod h1:KgnwoLYCZ8IQu3XUZ8Nc/bM9CCZFOyjUNOSygVozoDg=
Expand Down Expand Up @@ -125,6 +125,7 @@ github.com/klauspost/compress v1.15.11 h1:Lcadnb3RKGin4FYM/orgq0qde+nc15E5Cbqg4B
github.com/klauspost/compress v1.15.11/go.mod h1:QPwzmACJjUTFsnSHH934V6woptycfrDDJnH7hvFVbGM=
github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo=
github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE=
github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk=
github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ=
github.com/kr/text v0.1.0 h1:45sCR5RtlFHMR4UwH9sdQ5TC8v0qDQCHnXt+kaKSTVE=
github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
Expand Down Expand Up @@ -254,6 +255,7 @@ google.golang.org/protobuf v1.31.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqw
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk=
gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c/go.mod h1:JHkPIbrfpd72SG/EVd6muEfDQjcINNoR0C8j2r3qZ4Q=
gopkg.in/natefinch/lumberjack.v2 v2.2.1 h1:bBRl1b0OH9s/DuPhuXpNl+VtCaJXFZ5/uEFST95x9zc=
gopkg.in/natefinch/lumberjack.v2 v2.2.1/go.mod h1:YD8tP3GAjkrDg1eZH7EGmyESg/lsYskCTPBJVb9jqSc=
gopkg.in/readline.v1 v1.0.0-20160726135117-62c6fe619375/go.mod h1:lNEQeAhU009zbRxng+XOj5ITVgY24WcbNnQopyfKoYQ=
Expand All @@ -265,6 +267,7 @@ gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
gopkg.in/yaml.v2 v2.2.4/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY=
gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ=
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
Expand Down
23 changes: 10 additions & 13 deletions rest/adminapitest/admin_api_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1472,7 +1472,6 @@ func TestCorruptDbConfigHandling(t *testing.T) {
base.SetUpTestLogging(t, base.LevelInfo, base.KeyConfig)

rt := rest.NewRestTester(t, &rest.RestTesterConfig{
CustomTestBucket: base.GetPersistentTestBucket(t),
PersistentConfig: true,
MutateStartupConfig: func(config *rest.StartupConfig) {
// configure the interval time to pick up new configs from the bucket to every 1 seconds
Expand Down Expand Up @@ -1557,7 +1556,6 @@ func TestBadConfigInsertionToBucket(t *testing.T) {
base.TestsRequireBootstrapConnection(t)

rt := rest.NewRestTester(t, &rest.RestTesterConfig{
CustomTestBucket: base.GetPersistentTestBucket(t),
PersistentConfig: true,
MutateStartupConfig: func(config *rest.StartupConfig) {
// configure the interval time to pick up new configs from the bucket to every 1 seconds
Expand Down Expand Up @@ -1607,12 +1605,8 @@ func TestBadConfigInsertionToBucket(t *testing.T) {
func TestMismatchedBucketNameOnDbConfigUpdate(t *testing.T) {
base.TestsRequireBootstrapConnection(t)
base.RequireNumTestBuckets(t, 2)
ctx := base.TestCtx(t)
tb1 := base.GetPersistentTestBucket(t)
defer tb1.Close(ctx)

rt := rest.NewRestTester(t, &rest.RestTesterConfig{
CustomTestBucket: base.GetPersistentTestBucket(t),
PersistentConfig: true,
MutateStartupConfig: func(config *rest.StartupConfig) {
// configure the interval time to pick up new configs from the bucket to every 1 seconds
Expand All @@ -1628,6 +1622,9 @@ func TestMismatchedBucketNameOnDbConfigUpdate(t *testing.T) {

// wait for db to come online
require.NoError(t, rt.WaitForDBOnline())
ctx := base.TestCtx(t)
tb1 := base.GetTestBucket(t)
defer tb1.Close(ctx)
badName := tb1.GetName()
dbConfig.Bucket = &badName

Expand All @@ -1643,11 +1640,11 @@ func TestMultipleBucketWithBadDbConfigScenario1(t *testing.T) {
base.TestsRequireBootstrapConnection(t)
base.RequireNumTestBuckets(t, 3)
ctx := base.TestCtx(t)
tb1 := base.GetPersistentTestBucket(t)
tb1 := base.GetTestBucket(t)
defer tb1.Close(ctx)
tb2 := base.GetPersistentTestBucket(t)
tb2 := base.GetTestBucket(t)
defer tb2.Close(ctx)
tb3 := base.GetPersistentTestBucket(t)
tb3 := base.GetTestBucket(t)
defer tb3.Close(ctx)

const groupID = "60ce5544-c368-4b08-b0ed-4ca3b37973f9"
Expand Down Expand Up @@ -1722,9 +1719,9 @@ func TestMultipleBucketWithBadDbConfigScenario2(t *testing.T) {

base.RequireNumTestBuckets(t, 3)
ctx := base.TestCtx(t)
tb1 := base.GetPersistentTestBucket(t)
tb1 := base.GetTestBucket(t)
defer tb1.Close(ctx)
tb2 := base.GetPersistentTestBucket(t)
tb2 := base.GetTestBucket(t)
defer tb2.Close(ctx)

rt1 := rest.NewRestTester(t, &rest.RestTesterConfig{
Expand Down Expand Up @@ -1792,9 +1789,9 @@ func TestMultipleBucketWithBadDbConfigScenario3(t *testing.T) {
base.TestsRequireBootstrapConnection(t)

ctx := base.TestCtx(t)
tb1 := base.GetPersistentTestBucket(t)
tb1 := base.GetTestBucket(t)
defer tb1.Close(ctx)
tb2 := base.GetPersistentTestBucket(t)
tb2 := base.GetTestBucket(t)
defer tb2.Close(ctx)

rt := rest.NewRestTester(t, &rest.RestTesterConfig{
Expand Down
1 change: 0 additions & 1 deletion rest/adminapitest/collections_admin_api_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -179,7 +179,6 @@ func TestRequireResync(t *testing.T) {
base.RequireNumTestDataStores(t, 2)
base.SetUpTestLogging(t, base.LevelInfo, base.KeyAll)
rtConfig := &rest.RestTesterConfig{
CustomTestBucket: base.GetPersistentTestBucket(t),
PersistentConfig: true,
}

Expand Down
2 changes: 1 addition & 1 deletion rest/api.go
Original file line number Diff line number Diff line change
Expand Up @@ -258,7 +258,7 @@ func (h *handler) handleFlush() error {
name := h.db.Name
config := h.server.GetDatabaseConfig(name)
h.server.RemoveDatabase(h.ctx(), name)
err := bucket.CloseAndDelete()
err := bucket.CloseAndDelete(h.ctx())
_, err2 := h.server.AddDatabaseFromConfig(h.ctx(), config.DatabaseConfig)
if err == nil {
err = err2
Expand Down
28 changes: 14 additions & 14 deletions rest/api_collections_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -267,7 +267,7 @@ func TestMultiCollectionChannelAccess(t *testing.T) {
base.SetUpTestLogging(t, base.LevelDebug, base.KeyAll)

ctx := base.TestCtx(t)
tb := base.GetPersistentTestBucket(t)
tb := base.GetTestBucket(t)
defer tb.Close(ctx)

scopesConfig := GetCollectionsConfig(t, tb, 2)
Expand All @@ -281,9 +281,8 @@ func TestMultiCollectionChannelAccess(t *testing.T) {
scopesConfig[scope].Collections[collection1] = &CollectionConfig{SyncFn: &c1SyncFunction}
scopesConfig[scope].Collections[collection2] = &CollectionConfig{SyncFn: &c1SyncFunction}

fmt.Println(scopesConfig)
rtConfig := &RestTesterConfig{
CustomTestBucket: tb.NoCloseClone(),
CustomTestBucket: tb,
DatabaseConfig: &DatabaseConfig{DbConfig: DbConfig{
Scopes: scopesConfig,
NumIndexReplicas: base.UintPtr(0),
Expand Down Expand Up @@ -337,16 +336,21 @@ func TestMultiCollectionChannelAccess(t *testing.T) {
RequireStatus(t, resp, http.StatusOK)

// Add a new collection and update the db config
scopesConfig = GetCollectionsConfig(t, tb, 3)
dataStoreNames = GetDataStoreNamesFromScopesConfig(scopesConfig)
scopesConfig3Collections := GetCollectionsConfig(t, tb, 3)
dataStoreNames = GetDataStoreNamesFromScopesConfig(scopesConfig3Collections)

collection3 := dataStoreNames[2].CollectionName()
scopesConfig[scope].Collections[collection1] = &CollectionConfig{SyncFn: &c1SyncFunction}
scopesConfig[scope].Collections[collection2] = &CollectionConfig{SyncFn: &c1SyncFunction}
scopesConfig[scope].Collections[collection3] = &CollectionConfig{SyncFn: &c1SyncFunction}
scopesConfigString, err := json.Marshal(scopesConfig)
scopesConfig3Collections[scope].Collections[collection1] = &CollectionConfig{SyncFn: &c1SyncFunction}
scopesConfig3Collections[scope].Collections[collection2] = &CollectionConfig{SyncFn: &c1SyncFunction}
scopesConfig3Collections[scope].Collections[collection3] = &CollectionConfig{SyncFn: &c1SyncFunction}
scopesConfigString, err := json.Marshal(scopesConfig3Collections)
require.NoError(t, err)

scopesConfig2Collections := GetCollectionsConfig(t, tb, 2)

scopesConfig2Collections[scope].Collections[collection1] = &CollectionConfig{SyncFn: &c1SyncFunction}
scopesConfig2Collections[scope].Collections[collection2] = &CollectionConfig{SyncFn: &c1SyncFunction}

resp = rt.SendAdminRequest("PUT", "/db/_config", fmt.Sprintf(
`{"bucket": "%s", "num_index_replicas": 0, "enable_shared_bucket_access": %t, "scopes":%s}`,
tb.GetName(), base.TestUseXattrs(), string(scopesConfigString)))
Expand Down Expand Up @@ -378,11 +382,7 @@ func TestMultiCollectionChannelAccess(t *testing.T) {
RequireStatus(t, resp, http.StatusOK)

// Remove collection and update the db config
scopesConfig = GetCollectionsConfig(t, tb, 2)

scopesConfig[scope].Collections[collection1] = &CollectionConfig{SyncFn: &c1SyncFunction}
scopesConfig[scope].Collections[collection2] = &CollectionConfig{SyncFn: &c1SyncFunction}
scopesConfigString, err = json.Marshal(scopesConfig)
scopesConfigString, err = json.Marshal(scopesConfig2Collections)
require.NoError(t, err)

resp = rt.SendAdminRequest("PUT", "/db/_config", fmt.Sprintf(
Expand Down
6 changes: 3 additions & 3 deletions rest/importtest/collections_import_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ func TestMultiCollectionImportFilter(t *testing.T) {
base.RequireNumTestDataStores(t, 3)

ctx := base.TestCtx(t)
testBucket := base.GetPersistentTestBucket(t)
testBucket := base.GetTestBucket(t)
defer testBucket.Close(ctx)

scopesConfig := rest.GetCollectionsConfig(t, testBucket, 2)
Expand Down Expand Up @@ -250,7 +250,7 @@ func TestMultiCollectionImportDynamicAddCollection(t *testing.T) {
base.RequireNumTestDataStores(t, 2)

ctx := base.TestCtx(t)
testBucket := base.GetPersistentTestBucket(t)
testBucket := base.GetTestBucket(t)
defer testBucket.Close(ctx)

rtConfig := &rest.RestTesterConfig{
Expand Down Expand Up @@ -346,7 +346,7 @@ func TestMultiCollectionImportRemoveCollection(t *testing.T) {
base.RequireNumTestDataStores(t, numCollections)

ctx := base.TestCtx(t)
testBucket := base.GetPersistentTestBucket(t)
testBucket := base.GetTestBucket(t)
defer testBucket.Close(ctx)

rtConfig := &rest.RestTesterConfig{
Expand Down
Loading

0 comments on commit 5cea24b

Please sign in to comment.