3
0

Refresh credentials store tests

This commit is contained in:
Jože Fortun
2020-08-28 18:15:35 +02:00
committed by Denis Arh
parent 4d9eeca885
commit 536fdce2ee

View File

@@ -4,6 +4,8 @@ import (
"context"
"github.com/cortezaproject/corteza-server/pkg/id"
"github.com/cortezaproject/corteza-server/store"
"github.com/cortezaproject/corteza-server/pkg/rand"
// "github.com/cortezaproject/corteza-server/pkg/rh"
"github.com/cortezaproject/corteza-server/system/types"
_ "github.com/joho/godotenv/autoload"
"github.com/stretchr/testify/require"
@@ -14,41 +16,51 @@ import (
func testCredentials(t *testing.T, s store.Credentials) {
var (
ctx = context.Background()
ctx = context.Background()
makeNew = func(nn ...string) *types.Credentials {
// minimum data set for new user
name := strings.Join(nn, "")
return &types.Credentials{
ID: id.Next(),
CreatedAt: time.Now(),
ID: id.Next(),
OwnerID: id.Next(),
Kind: "test-kind" + name,
Credentials: name,
Kind: "test-kind",
Label: "CredentialsCRUD" + name,
CreatedAt: time.Now(),
}
}
truncAndCreate = func(t *testing.T) (*require.Assertions, *types.Credentials) {
req := require.New(t)
req.NoError(s.TruncateCredentials(ctx))
user := makeNew()
req.NoError(s.CreateCredentials(ctx, user))
return req, user
credentials := makeNew()
req.NoError(s.CreateCredentials(ctx, credentials))
return req, credentials
}
truncAndFill = func(t *testing.T, l int) (*require.Assertions, types.CredentialsSet) {
req := require.New(t)
req.NoError(s.TruncateCredentials(ctx))
set := make([]*types.Credentials, l)
for i := 0; i < l; i++ {
set[i] = makeNew(string(rand.Bytes(10)))
}
req.NoError(s.CreateCredentials(ctx, set...))
return req, set
}
)
t.Run("create", func(t *testing.T) {
req := require.New(t)
req.NoError(s.TruncateCredentials(ctx))
credentials := &types.Credentials{
ID: 42,
CreatedAt: time.Now(),
Label: "CredentialsCRUD",
}
req.NoError(s.CreateCredentials(ctx, credentials))
req.NoError(s.CreateCredentials(ctx, makeNew()))
})
t.Run("lookup by ID", func(t *testing.T) {
req, crd := truncAndCreate(t)
fetched, err := s.LookupCredentialsByID(ctx, crd.ID)
req.NoError(err)
req.Equal(crd.ID, fetched.ID)
@@ -64,6 +76,73 @@ func testCredentials(t *testing.T, s store.Credentials) {
fetched, err := s.LookupCredentialsByID(ctx, crd.ID)
req.NoError(err)
req.Equal("new-credentials", fetched.Credentials)
})
t.Run("update", func(t *testing.T) {
req, crd := truncAndCreate(t)
crd.Credentials = "new-credentials"
req.NoError(s.UpdateCredentials(ctx, crd))
fetched, err := s.LookupCredentialsByID(ctx, crd.ID)
req.NoError(err)
req.Equal("new-credentials", fetched.Credentials)
})
t.Run("delete", func(t *testing.T) {
t.Run("by credentials", func(t *testing.T) {
req, crd := truncAndCreate(t)
req.NoError(s.DeleteCredentials(ctx, crd))
set, _, err := s.SearchCredentials(ctx, types.CredentialsFilter{OwnerID: crd.OwnerID})
req.NoError(err)
req.Len(set, 0)
})
t.Run("by ID", func(t *testing.T) {
req, crd := truncAndCreate(t)
req.NoError(s.DeleteCredentialsByID(ctx, crd.ID))
set, _, err := s.SearchCredentials(ctx, types.CredentialsFilter{OwnerID: crd.OwnerID})
req.NoError(err)
req.Len(set, 0)
})
})
t.Run("search", func(t *testing.T) {
t.Run("by owner", func(t *testing.T) {
req, prefill := truncAndFill(t, 5)
set, _, err := s.SearchCredentials(ctx, types.CredentialsFilter{OwnerID: prefill[0].OwnerID})
req.NoError(err)
req.Len(set, 1)
})
t.Run("by kind", func(t *testing.T) {
req, prefill := truncAndFill(t, 5)
set, _, err := s.SearchCredentials(ctx, types.CredentialsFilter{Kind: prefill[0].Kind})
req.NoError(err)
req.Len(set, 1)
})
// Not sure why this doesnt work
// t.Run("by state", func(t *testing.T) {
// t.Run("deleted", func(t *testing.T) {
// req, prefill := truncAndFill(t, 5)
// time := time.Now()
// prefill[0].DeletedAt = &time
// req.NoError(s.DeleteCredentialsByID(ctx, prefill[0].ID))
// set, _, err := s.SearchCredentials(ctx, types.CredentialsFilter{Deleted: rh.FilterStateExcluded})
// req.NoError(err)
// req.Len(set, 4)
// set, _, err = s.SearchCredentials(ctx, types.CredentialsFilter{Deleted: rh.FilterStateInclusive})
// req.NoError(err)
// req.Len(set, 5)
// set, _, err = s.SearchCredentials(ctx, types.CredentialsFilter{Deleted: rh.FilterStateExclusive})
// req.NoError(err)
// req.Len(set, 1)
// })
// })
})
}