2020-03-17 19:23:00 +00:00
|
|
|
package tenant_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
2020-04-02 09:01:44 +00:00
|
|
|
"github.com/influxdata/influxdb/v2"
|
2020-04-03 17:39:20 +00:00
|
|
|
"github.com/influxdata/influxdb/v2/bolt"
|
|
|
|
"github.com/influxdata/influxdb/v2/inmem"
|
|
|
|
"github.com/influxdata/influxdb/v2/kv"
|
2020-07-01 11:08:20 +00:00
|
|
|
"github.com/influxdata/influxdb/v2/kv/migration/all"
|
2020-04-02 09:01:44 +00:00
|
|
|
"github.com/influxdata/influxdb/v2/tenant"
|
|
|
|
influxdbtesting "github.com/influxdata/influxdb/v2/testing"
|
2020-03-17 19:23:00 +00:00
|
|
|
"go.uber.org/zap/zaptest"
|
|
|
|
)
|
|
|
|
|
2020-07-01 11:08:20 +00:00
|
|
|
func NewTestBoltStore(t *testing.T) (kv.SchemaStore, func(), error) {
|
2020-03-17 19:23:00 +00:00
|
|
|
f, err := ioutil.TempFile("", "influxdata-bolt-")
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, errors.New("unable to open temporary boltdb file")
|
|
|
|
}
|
|
|
|
f.Close()
|
|
|
|
|
|
|
|
path := f.Name()
|
2020-07-24 09:13:05 +00:00
|
|
|
s := bolt.NewKVStore(zaptest.NewLogger(t), path, bolt.WithNoSync)
|
2020-03-17 19:23:00 +00:00
|
|
|
if err := s.Open(context.Background()); err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
2020-07-01 11:08:20 +00:00
|
|
|
// apply all kv migrations
|
|
|
|
ctx := context.Background()
|
|
|
|
if err := all.Up(ctx, zaptest.NewLogger(t), s); err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
2020-03-17 19:23:00 +00:00
|
|
|
close := func() {
|
|
|
|
s.Close()
|
|
|
|
os.Remove(path)
|
|
|
|
}
|
|
|
|
|
|
|
|
return s, close, nil
|
|
|
|
}
|
|
|
|
|
2020-07-01 11:08:20 +00:00
|
|
|
func NewTestInmemStore(t *testing.T) (kv.SchemaStore, func(), error) {
|
|
|
|
s := inmem.NewKVStore()
|
|
|
|
// apply all kv migrations
|
|
|
|
ctx := context.Background()
|
|
|
|
if err := all.Up(ctx, zaptest.NewLogger(t), s); err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return s, func() {}, nil
|
2020-03-17 19:23:00 +00:00
|
|
|
}
|
2020-04-02 09:01:44 +00:00
|
|
|
|
|
|
|
func TestBoltTenantService(t *testing.T) {
|
|
|
|
influxdbtesting.TenantService(t, initBoltTenantService)
|
|
|
|
}
|
|
|
|
|
|
|
|
func initBoltTenantService(t *testing.T, f influxdbtesting.TenantFields) (influxdb.TenantService, func()) {
|
|
|
|
s, closeBolt, err := NewTestBoltStore(t)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("failed to create new kv store: %v", err)
|
|
|
|
}
|
2020-07-01 11:08:20 +00:00
|
|
|
|
2020-08-11 14:56:42 +00:00
|
|
|
store := tenant.NewStore(s)
|
|
|
|
|
|
|
|
if f.OrgIDGenerator != nil {
|
|
|
|
store.OrgIDGen = f.OrgIDGenerator
|
|
|
|
}
|
|
|
|
|
|
|
|
if f.BucketIDGenerator != nil {
|
|
|
|
store.BucketIDGen = f.BucketIDGenerator
|
|
|
|
}
|
|
|
|
|
|
|
|
svc := tenant.NewService(store)
|
2020-04-02 09:01:44 +00:00
|
|
|
|
|
|
|
for _, u := range f.Users {
|
|
|
|
if err := svc.CreateUser(context.Background(), u); err != nil {
|
|
|
|
t.Fatalf("error populating users: %v", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for i := range f.Passwords {
|
|
|
|
if err := svc.SetPassword(context.Background(), f.Users[i].ID, f.Passwords[i]); err != nil {
|
|
|
|
t.Fatalf("error setting passsword user, %s %s: %v", f.Users[i].Name, f.Passwords[i], err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, o := range f.Organizations {
|
|
|
|
if err := svc.CreateOrganization(context.Background(), o); err != nil {
|
|
|
|
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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, m := range f.UserResourceMappings {
|
|
|
|
if err := svc.CreateUserResourceMapping(context.Background(), m); err != nil {
|
|
|
|
t.Fatalf("failed to populate mappings: %v", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return svc, func() {
|
|
|
|
for _, u := range f.Users {
|
|
|
|
if err := svc.DeleteUser(context.Background(), u.ID); err != nil {
|
|
|
|
t.Logf("error removing users: %v", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, m := range f.UserResourceMappings {
|
|
|
|
if err := svc.DeleteUserResourceMapping(context.Background(), m.ResourceID, m.UserID); err != nil {
|
|
|
|
t.Logf("failed to remove user resource mapping: %v", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, o := range f.Organizations {
|
|
|
|
if err := svc.DeleteOrganization(context.Background(), o.ID); err != nil {
|
|
|
|
t.Logf("failed to remove organization: %v", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
closeBolt()
|
|
|
|
}
|
|
|
|
}
|