2020-03-11 18:31:33 +00:00
|
|
|
package tenant_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
2020-08-11 14:56:42 +00:00
|
|
|
"time"
|
2020-03-11 18:31:33 +00:00
|
|
|
|
2020-04-03 17:39:20 +00:00
|
|
|
"github.com/influxdata/influxdb/v2"
|
|
|
|
"github.com/influxdata/influxdb/v2/kv"
|
2020-08-11 14:56:42 +00:00
|
|
|
"github.com/influxdata/influxdb/v2/mock"
|
2020-04-03 17:39:20 +00:00
|
|
|
"github.com/influxdata/influxdb/v2/tenant"
|
2020-08-11 14:56:42 +00:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/require"
|
2020-03-11 18:31:33 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// type Organization struct {
|
|
|
|
// ID ID `json:"id,omitempty"`
|
|
|
|
// Name string `json:"name"`
|
|
|
|
// Description string `json:"description"`
|
|
|
|
// CRUDLog
|
|
|
|
// }
|
|
|
|
|
2020-08-11 14:56:42 +00:00
|
|
|
const (
|
|
|
|
firstOrgID influxdb.ID = (iota + 1)
|
|
|
|
secondOrgID
|
|
|
|
thirdOrgID
|
|
|
|
fourthOrgID
|
|
|
|
fifthOrgID
|
|
|
|
)
|
|
|
|
|
2020-03-11 18:31:33 +00:00
|
|
|
func TestOrg(t *testing.T) {
|
2020-08-11 14:56:42 +00:00
|
|
|
var (
|
|
|
|
aTime = time.Date(2020, 7, 23, 10, 0, 0, 0, time.UTC)
|
|
|
|
testOrgs = func(count int, visit ...func(*influxdb.Organization)) (orgs []*influxdb.Organization) {
|
|
|
|
for i := 1; i <= count; i++ {
|
|
|
|
org := &influxdb.Organization{
|
|
|
|
ID: influxdb.ID(i),
|
|
|
|
Name: fmt.Sprintf("org%d", i),
|
|
|
|
Description: "words",
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(visit) > 0 {
|
|
|
|
visit[0](org)
|
|
|
|
}
|
|
|
|
|
|
|
|
orgs = append(orgs, org)
|
2020-03-11 18:31:33 +00:00
|
|
|
}
|
2020-08-11 14:56:42 +00:00
|
|
|
|
|
|
|
return
|
2020-03-11 18:31:33 +00:00
|
|
|
}
|
2020-08-11 14:56:42 +00:00
|
|
|
|
|
|
|
withCrudLog = func(o *influxdb.Organization) {
|
|
|
|
o.CRUDLog = influxdb.CRUDLog{
|
|
|
|
CreatedAt: aTime,
|
|
|
|
UpdatedAt: aTime,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
simpleSetup = func(t *testing.T, store *tenant.Store, tx kv.Tx) {
|
|
|
|
store.OrgIDGen = mock.NewIncrementingIDGenerator(1)
|
|
|
|
for _, org := range testOrgs(10) {
|
|
|
|
require.NoError(t, store.CreateOrg(context.Background(), tx, org))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
)
|
2020-03-11 18:31:33 +00:00
|
|
|
|
|
|
|
st := []struct {
|
|
|
|
name string
|
|
|
|
setup func(*testing.T, *tenant.Store, kv.Tx)
|
|
|
|
update func(*testing.T, *tenant.Store, kv.Tx)
|
|
|
|
results func(*testing.T, *tenant.Store, kv.Tx)
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "create",
|
|
|
|
setup: simpleSetup,
|
|
|
|
results: func(t *testing.T, store *tenant.Store, tx kv.Tx) {
|
|
|
|
orgs, err := store.ListOrgs(context.Background(), tx)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2020-08-11 14:56:42 +00:00
|
|
|
assert.Len(t, orgs, 10)
|
2020-03-11 18:31:33 +00:00
|
|
|
|
2020-08-11 14:56:42 +00:00
|
|
|
expected := testOrgs(10, withCrudLog)
|
|
|
|
assert.Equal(t, expected, orgs)
|
2020-03-11 18:31:33 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "get",
|
|
|
|
setup: simpleSetup,
|
|
|
|
results: func(t *testing.T, store *tenant.Store, tx kv.Tx) {
|
2020-08-11 14:56:42 +00:00
|
|
|
org, err := store.GetOrg(context.Background(), tx, fifthOrgID)
|
2020-03-11 18:31:33 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
expected := &influxdb.Organization{
|
2020-08-11 14:56:42 +00:00
|
|
|
ID: fifthOrgID,
|
2020-03-11 18:31:33 +00:00
|
|
|
Name: "org5",
|
|
|
|
Description: "words",
|
|
|
|
CRUDLog: influxdb.CRUDLog{
|
|
|
|
CreatedAt: org.CreatedAt,
|
|
|
|
UpdatedAt: org.UpdatedAt,
|
|
|
|
},
|
|
|
|
}
|
2020-08-11 14:56:42 +00:00
|
|
|
require.Equal(t, expected, org)
|
2020-03-11 18:31:33 +00:00
|
|
|
|
|
|
|
org, err = store.GetOrgByName(context.Background(), tx, "org5")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-08-11 14:56:42 +00:00
|
|
|
require.Equal(t, expected, org)
|
2020-03-11 18:31:33 +00:00
|
|
|
|
|
|
|
if _, err := store.GetOrg(context.Background(), tx, 500); err != tenant.ErrOrgNotFound {
|
|
|
|
t.Fatal("failed to get correct error when looking for invalid org by id")
|
|
|
|
}
|
|
|
|
|
2020-03-17 19:23:00 +00:00
|
|
|
if _, err := store.GetOrgByName(context.Background(), tx, "notaorg"); err.Error() != tenant.OrgNotFoundByName("notaorg").Error() {
|
2020-03-11 18:31:33 +00:00
|
|
|
t.Fatal("failed to get correct error when looking for invalid org by name")
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "list",
|
|
|
|
setup: simpleSetup,
|
|
|
|
results: func(t *testing.T, store *tenant.Store, tx kv.Tx) {
|
|
|
|
orgs, err := store.ListOrgs(context.Background(), tx)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2020-08-11 14:56:42 +00:00
|
|
|
require.Len(t, orgs, 10)
|
2020-03-11 18:31:33 +00:00
|
|
|
|
2020-08-11 14:56:42 +00:00
|
|
|
expected := testOrgs(10, withCrudLog)
|
|
|
|
require.Equal(t, expected, orgs)
|
2020-03-11 18:31:33 +00:00
|
|
|
orgs, err = store.ListOrgs(context.Background(), tx, influxdb.FindOptions{Limit: 4})
|
2020-08-11 14:56:42 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
assert.Len(t, orgs, 4)
|
|
|
|
assert.Equal(t, expected[:4], orgs)
|
2020-03-11 18:31:33 +00:00
|
|
|
|
|
|
|
orgs, err = store.ListOrgs(context.Background(), tx, influxdb.FindOptions{Offset: 3})
|
2020-08-11 14:56:42 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
assert.Len(t, orgs, 7)
|
|
|
|
assert.Equal(t, expected[3:], orgs)
|
2020-03-11 18:31:33 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "update",
|
|
|
|
setup: simpleSetup,
|
|
|
|
update: func(t *testing.T, store *tenant.Store, tx kv.Tx) {
|
|
|
|
org5 := "org5"
|
2020-08-11 14:56:42 +00:00
|
|
|
_, err := store.UpdateOrg(context.Background(), tx, thirdOrgID, influxdb.OrganizationUpdate{Name: &org5})
|
2020-03-17 19:23:00 +00:00
|
|
|
if err.Error() != tenant.OrgAlreadyExistsError(org5).Error() {
|
2020-03-11 18:31:33 +00:00
|
|
|
t.Fatal("failed to error on duplicate orgname")
|
|
|
|
}
|
|
|
|
|
|
|
|
org30 := "org30"
|
2020-08-11 14:56:42 +00:00
|
|
|
_, err = store.UpdateOrg(context.Background(), tx, thirdOrgID, influxdb.OrganizationUpdate{Name: &org30})
|
|
|
|
require.NoError(t, err)
|
2020-03-11 18:31:33 +00:00
|
|
|
|
|
|
|
description := "notWords"
|
2020-08-11 14:56:42 +00:00
|
|
|
_, err = store.UpdateOrg(context.Background(), tx, thirdOrgID, influxdb.OrganizationUpdate{Description: &description})
|
|
|
|
require.NoError(t, err)
|
2020-03-11 18:31:33 +00:00
|
|
|
},
|
|
|
|
results: func(t *testing.T, store *tenant.Store, tx kv.Tx) {
|
|
|
|
orgs, err := store.ListOrgs(context.Background(), tx)
|
2020-08-11 14:56:42 +00:00
|
|
|
require.NoError(t, err)
|
2020-03-11 18:31:33 +00:00
|
|
|
|
2020-08-11 14:56:42 +00:00
|
|
|
assert.Len(t, orgs, 10)
|
2020-03-11 18:31:33 +00:00
|
|
|
|
2020-08-11 14:56:42 +00:00
|
|
|
expected := testOrgs(10, withCrudLog)
|
2020-03-11 18:31:33 +00:00
|
|
|
expected[2].Name = "org30"
|
|
|
|
expected[2].Description = "notWords"
|
2020-08-11 14:56:42 +00:00
|
|
|
require.Equal(t, expected, orgs)
|
2020-03-11 18:31:33 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "delete",
|
|
|
|
setup: simpleSetup,
|
|
|
|
update: func(t *testing.T, store *tenant.Store, tx kv.Tx) {
|
2020-08-11 14:56:42 +00:00
|
|
|
err := store.DeleteOrg(context.Background(), tx, firstOrgID)
|
|
|
|
require.NoError(t, err)
|
2020-03-11 18:31:33 +00:00
|
|
|
|
2020-08-11 14:56:42 +00:00
|
|
|
err = store.DeleteOrg(context.Background(), tx, firstOrgID)
|
2020-03-11 18:31:33 +00:00
|
|
|
if err != tenant.ErrOrgNotFound {
|
|
|
|
t.Fatal("invalid error when deleting org that has already been deleted", err)
|
|
|
|
}
|
|
|
|
|
2020-08-11 14:56:42 +00:00
|
|
|
err = store.DeleteOrg(context.Background(), tx, thirdOrgID)
|
|
|
|
require.NoError(t, err)
|
2020-03-11 18:31:33 +00:00
|
|
|
},
|
|
|
|
results: func(t *testing.T, store *tenant.Store, tx kv.Tx) {
|
|
|
|
orgs, err := store.ListOrgs(context.Background(), tx)
|
2020-08-11 14:56:42 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
assert.Len(t, orgs, 8)
|
2020-03-11 18:31:33 +00:00
|
|
|
|
2020-08-11 14:56:42 +00:00
|
|
|
all := testOrgs(10, withCrudLog)
|
|
|
|
// deleted first and third item
|
|
|
|
expected := append(all[1:2], all[3:]...)
|
|
|
|
require.Equal(t, expected, orgs)
|
2020-03-11 18:31:33 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, testScenario := range st {
|
|
|
|
t.Run(testScenario.name, func(t *testing.T) {
|
2020-07-01 11:08:20 +00:00
|
|
|
s, closeS, err := NewTestInmemStore(t)
|
2020-03-11 18:31:33 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-07-01 11:08:20 +00:00
|
|
|
defer closeS()
|
|
|
|
|
2020-08-11 14:56:42 +00:00
|
|
|
ts := tenant.NewStore(s, tenant.WithNow(func() time.Time {
|
|
|
|
return aTime
|
|
|
|
}))
|
2020-03-11 18:31:33 +00:00
|
|
|
|
|
|
|
// setup
|
|
|
|
if testScenario.setup != nil {
|
|
|
|
err := ts.Update(context.Background(), func(tx kv.Tx) error {
|
|
|
|
testScenario.setup(t, ts, tx)
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// update
|
|
|
|
if testScenario.update != nil {
|
|
|
|
err := ts.Update(context.Background(), func(tx kv.Tx) error {
|
|
|
|
testScenario.update(t, ts, tx)
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// results
|
|
|
|
if testScenario.results != nil {
|
|
|
|
err := ts.View(context.Background(), func(tx kv.Tx) error {
|
|
|
|
testScenario.results(t, ts, tx)
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|