2020-03-17 19:23:00 +00:00
|
|
|
package tenant_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
|
2020-04-03 17:39:20 +00:00
|
|
|
"github.com/influxdata/influxdb/v2"
|
|
|
|
"github.com/influxdata/influxdb/v2/kv"
|
|
|
|
"github.com/influxdata/influxdb/v2/tenant"
|
|
|
|
influxdbtesting "github.com/influxdata/influxdb/v2/testing"
|
2020-03-17 19:23:00 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestBoltBucketService(t *testing.T) {
|
|
|
|
influxdbtesting.BucketService(initBoltBucketService, t, influxdbtesting.WithoutHooks())
|
|
|
|
}
|
|
|
|
|
|
|
|
func initBoltBucketService(f influxdbtesting.BucketFields, t *testing.T) (influxdb.BucketService, string, func()) {
|
|
|
|
s, closeBolt, err := NewTestInmemStore(t)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to create new kv store: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
svc, op, closeSvc := initBucketService(s, f, t)
|
|
|
|
return svc, op, func() {
|
|
|
|
closeSvc()
|
|
|
|
closeBolt()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-01 11:08:20 +00:00
|
|
|
func initBucketService(s kv.SchemaStore, f influxdbtesting.BucketFields, t *testing.T) (influxdb.BucketService, string, func()) {
|
|
|
|
storage := tenant.NewStore(s)
|
2020-03-17 19:23:00 +00:00
|
|
|
svc := tenant.NewService(storage)
|
|
|
|
|
|
|
|
for _, o := range f.Organizations {
|
2020-07-24 10:35:41 +00:00
|
|
|
// use storage create org in order to avoid creating system buckets
|
|
|
|
if err := s.Update(context.Background(), func(tx kv.Tx) error {
|
|
|
|
return storage.CreateOrg(tx.Context(), tx, o)
|
|
|
|
}); err != nil {
|
2020-03-17 19:23:00 +00:00
|
|
|
t.Fatalf("failed to populate organizations: %s", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, b := range f.Buckets {
|
|
|
|
if err := svc.CreateBucket(context.Background(), b); err != nil {
|
|
|
|
t.Fatalf("failed to populate buckets: %s", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return svc, "tenant/", func() {
|
|
|
|
for _, o := range f.Organizations {
|
|
|
|
if err := svc.DeleteOrganization(context.Background(), o.ID); err != nil {
|
|
|
|
t.Logf("failed to remove organization: %v", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-05-22 15:30:14 +00:00
|
|
|
|
|
|
|
func TestBucketFind(t *testing.T) {
|
|
|
|
s, close, err := NewTestInmemStore(t)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
defer close()
|
|
|
|
|
2020-07-01 11:08:20 +00:00
|
|
|
storage := tenant.NewStore(s)
|
2020-05-22 15:30:14 +00:00
|
|
|
svc := tenant.NewService(storage)
|
|
|
|
o := &influxdb.Organization{
|
|
|
|
Name: "theorg",
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := svc.CreateOrganization(context.Background(), o); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
name := "thebucket"
|
|
|
|
_, _, err = svc.FindBuckets(context.Background(), influxdb.BucketFilter{
|
|
|
|
Name: &name,
|
|
|
|
Org: &o.Name,
|
|
|
|
})
|
|
|
|
if err.Error() != `bucket "thebucket" not found` {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
2020-05-26 21:36:01 +00:00
|
|
|
|
|
|
|
func TestSystemBucketsInNameFind(t *testing.T) {
|
|
|
|
s, close, err := NewTestInmemStore(t)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
defer close()
|
|
|
|
|
2020-07-01 11:08:20 +00:00
|
|
|
storage := tenant.NewStore(s)
|
2020-05-26 21:36:01 +00:00
|
|
|
svc := tenant.NewService(storage)
|
|
|
|
o := &influxdb.Organization{
|
|
|
|
Name: "theorg",
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := svc.CreateOrganization(context.Background(), o); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
b := &influxdb.Bucket{
|
|
|
|
OrgID: o.ID,
|
|
|
|
Name: "thebucket",
|
|
|
|
}
|
|
|
|
if err := svc.CreateBucket(context.Background(), b); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
name := "thebucket"
|
|
|
|
buckets, _, _ := svc.FindBuckets(context.Background(), influxdb.BucketFilter{
|
|
|
|
Name: &name,
|
|
|
|
Org: &o.Name,
|
|
|
|
})
|
|
|
|
if len(buckets) != 1 {
|
|
|
|
t.Fatal("failed to return a single bucket when doing a bucket lookup by name")
|
|
|
|
}
|
|
|
|
}
|