mirror of
https://github.com/mainflux/mainflux.git
synced 2025-04-24 13:48:49 +08:00

* NOISSUE - Rename pkg aliases uuidProvider into uuid and fix authn typo Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Add missing error checks Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Use global uuidProvider Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Use expTime globally Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix user uuid provider Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix review Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Use idProvider name Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Use idProvider instead of uuidProvider Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Use idProvider instead of uuidProvider Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com>
414 lines
11 KiB
Go
414 lines
11 KiB
Go
// Copyright (c) Mainflux
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package postgres_test
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/mainflux/mainflux/pkg/errors"
|
|
"github.com/mainflux/mainflux/users"
|
|
"github.com/mainflux/mainflux/users/postgres"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
const (
|
|
maxNameSize = 254
|
|
maxDescSize = 1024
|
|
groupName = "Mainflux"
|
|
password = "12345678"
|
|
)
|
|
|
|
var (
|
|
invalidName = strings.Repeat("m", maxNameSize+1)
|
|
invalidDesc = strings.Repeat("m", maxDescSize+1)
|
|
)
|
|
|
|
func TestGroupSave(t *testing.T) {
|
|
dbMiddleware := postgres.NewDatabase(db)
|
|
repo := postgres.NewGroupRepo(dbMiddleware)
|
|
userRepo := postgres.NewUserRepo(dbMiddleware)
|
|
uid, err := idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("user id unexpected error: %s", err))
|
|
user := users.User{
|
|
ID: uid,
|
|
Email: "TestGroupSave@mainflux.com",
|
|
Password: password,
|
|
}
|
|
_, err = userRepo.Save(context.Background(), user)
|
|
require.Nil(t, err, fmt.Sprintf("save got unexpected error: %s", err))
|
|
|
|
user, err = userRepo.RetrieveByEmail(context.Background(), user.Email)
|
|
require.Nil(t, err, fmt.Sprintf("retrieve got unexpected error: %s", err))
|
|
|
|
uid, err = idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("group id unexpected error: %s", err))
|
|
group := users.Group{
|
|
ID: uid,
|
|
Name: "TestGroupSave",
|
|
OwnerID: user.ID,
|
|
}
|
|
|
|
cases := []struct {
|
|
desc string
|
|
group users.Group
|
|
err error
|
|
}{
|
|
{
|
|
desc: "create new group",
|
|
group: group,
|
|
err: nil,
|
|
},
|
|
{
|
|
desc: "create group that already exist",
|
|
group: group,
|
|
err: users.ErrGroupConflict,
|
|
},
|
|
{
|
|
desc: "create thing with invalid name",
|
|
group: users.Group{
|
|
Name: "x^%",
|
|
},
|
|
err: users.ErrMalformedEntity,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
_, err := repo.Save(context.Background(), tc.group)
|
|
assert.True(t, errors.Contains(err, tc.err), fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
}
|
|
|
|
func TestGroupRetrieveByID(t *testing.T) {
|
|
dbMiddleware := postgres.NewDatabase(db)
|
|
repo := postgres.NewGroupRepo(dbMiddleware)
|
|
userRepo := postgres.NewUserRepo(dbMiddleware)
|
|
uid, err := idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("got unexpected error: %s", err))
|
|
user := users.User{
|
|
ID: uid,
|
|
Email: "TestGroupRetrieveByID@mainflux.com",
|
|
Password: password,
|
|
}
|
|
_, err = userRepo.Save(context.Background(), user)
|
|
require.Nil(t, err, fmt.Sprintf("save got unexpected error: %s", err))
|
|
|
|
user, err = userRepo.RetrieveByEmail(context.Background(), user.Email)
|
|
require.Nil(t, err, fmt.Sprintf("retrieve got unexpected error: %s", err))
|
|
|
|
gid, err := idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("group id unexpected error: %s", err))
|
|
group1 := users.Group{
|
|
ID: gid,
|
|
Name: groupName + "TestGroupRetrieveByID1",
|
|
OwnerID: user.ID,
|
|
}
|
|
|
|
gid, err = idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("group id unexpected error: %s", err))
|
|
group2 := users.Group{
|
|
ID: gid,
|
|
Name: groupName + "TestGroupRetrieveByID2",
|
|
OwnerID: user.ID,
|
|
}
|
|
|
|
g1, err := repo.Save(context.Background(), group1)
|
|
require.Nil(t, err, fmt.Sprintf("group save got unexpected error: %s", err))
|
|
|
|
g2, err := repo.Save(context.Background(), group2)
|
|
require.Nil(t, err, fmt.Sprintf("group save got unexpected error: %s", err))
|
|
|
|
g2.ID, err = idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("failed to generate id error: %s", err))
|
|
|
|
cases := []struct {
|
|
desc string
|
|
group users.Group
|
|
err error
|
|
}{
|
|
{
|
|
desc: "retrieve group for valid id",
|
|
group: g1,
|
|
err: nil,
|
|
},
|
|
{
|
|
desc: "retrieve group for invalid id",
|
|
group: g2,
|
|
err: users.ErrNotFound,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
_, err := repo.RetrieveByID(context.Background(), tc.group.ID)
|
|
assert.True(t, errors.Contains(err, tc.err), fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
}
|
|
|
|
func TestGroupUpdate(t *testing.T) {
|
|
dbMiddleware := postgres.NewDatabase(db)
|
|
groupRepo := postgres.NewGroupRepo(dbMiddleware)
|
|
|
|
gid, err := idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("group id unexpected error: %s", err))
|
|
group := users.Group{
|
|
ID: gid,
|
|
Name: groupName,
|
|
}
|
|
|
|
_, err = groupRepo.Save(context.Background(), group)
|
|
require.Nil(t, err, fmt.Sprintf("group save got unexpected error: %s", err))
|
|
|
|
cases := []struct {
|
|
desc string
|
|
group users.Group
|
|
err error
|
|
}{
|
|
{
|
|
desc: "update group for existing id",
|
|
group: users.Group{
|
|
ID: gid,
|
|
Name: groupName + "-1",
|
|
},
|
|
err: nil,
|
|
},
|
|
{
|
|
desc: "update group for non-existing id",
|
|
group: users.Group{
|
|
ID: "wrong",
|
|
Name: groupName + "-2",
|
|
},
|
|
err: users.ErrUpdateGroup,
|
|
},
|
|
{
|
|
desc: "update group for invalid name",
|
|
group: users.Group{
|
|
ID: gid,
|
|
Name: invalidName,
|
|
},
|
|
err: users.ErrUpdateGroup,
|
|
},
|
|
{
|
|
desc: "update group for invalid description",
|
|
group: users.Group{
|
|
ID: gid,
|
|
Description: invalidDesc,
|
|
},
|
|
err: users.ErrUpdateGroup,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
err := groupRepo.Update(context.Background(), tc.group)
|
|
assert.True(t, errors.Contains(err, tc.err), fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
}
|
|
|
|
func TestGroupDelete(t *testing.T) {
|
|
dbMiddleware := postgres.NewDatabase(db)
|
|
repo := postgres.NewGroupRepo(dbMiddleware)
|
|
userRepo := postgres.NewUserRepo(dbMiddleware)
|
|
uid, err := idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("got unexpected error: %s", err))
|
|
user := users.User{
|
|
ID: uid,
|
|
Email: "TestGroupDelete@mainflux.com",
|
|
Password: password,
|
|
}
|
|
_, err = userRepo.Save(context.Background(), user)
|
|
require.Nil(t, err, fmt.Sprintf("save got unexpected error: %s", err))
|
|
|
|
user, err = userRepo.RetrieveByEmail(context.Background(), user.Email)
|
|
require.Nil(t, err, fmt.Sprintf("retrieve got unexpected error: %s", err))
|
|
|
|
gid, err := idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("group id unexpected error: %s", err))
|
|
group1 := users.Group{
|
|
ID: gid,
|
|
Name: groupName + "TestGroupDelete1",
|
|
OwnerID: user.ID,
|
|
}
|
|
|
|
g1, err := repo.Save(context.Background(), group1)
|
|
require.Nil(t, err, fmt.Sprintf("group save got unexpected error: %s", err))
|
|
|
|
err = repo.Assign(context.Background(), user.ID, g1.ID)
|
|
require.Nil(t, err, fmt.Sprintf("failed to assign user to a group: %s", err))
|
|
|
|
gid, err = idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("group id unexpected error: %s", err))
|
|
group2 := users.Group{
|
|
ID: gid,
|
|
Name: groupName + "TestGroupDelete2",
|
|
OwnerID: user.ID,
|
|
}
|
|
|
|
g2, err := repo.Save(context.Background(), group2)
|
|
require.Nil(t, err, fmt.Sprintf("group save got unexpected error: %s", err))
|
|
|
|
cases := []struct {
|
|
desc string
|
|
group users.Group
|
|
err error
|
|
}{
|
|
{
|
|
desc: "delete group for existing id",
|
|
group: g2,
|
|
err: nil,
|
|
},
|
|
{
|
|
desc: "delete group for non-existing id",
|
|
group: g2,
|
|
err: users.ErrDeleteGroupMissing,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
err := repo.Delete(context.Background(), tc.group.ID)
|
|
assert.True(t, errors.Contains(err, tc.err), fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
}
|
|
|
|
func TestAssignUser(t *testing.T) {
|
|
dbMiddleware := postgres.NewDatabase(db)
|
|
repo := postgres.NewGroupRepo(dbMiddleware)
|
|
userRepo := postgres.NewUserRepo(dbMiddleware)
|
|
uid, err := idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("got unexpected error: %s", err))
|
|
user := users.User{
|
|
ID: uid,
|
|
Email: "TestAssignUser@mainflux.com",
|
|
Password: password,
|
|
}
|
|
|
|
_, err = userRepo.Save(context.Background(), user)
|
|
require.Nil(t, err, fmt.Sprintf("save got unexpected error: %s", err))
|
|
|
|
user, err = userRepo.RetrieveByEmail(context.Background(), user.Email)
|
|
require.Nil(t, err, fmt.Sprintf("retrieve got unexpected error: %s", err))
|
|
|
|
gid, err := idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("group id unexpected error: %s", err))
|
|
group1 := users.Group{
|
|
ID: gid,
|
|
Name: groupName + "TestAssignUser1",
|
|
OwnerID: user.ID,
|
|
}
|
|
|
|
g1, err := repo.Save(context.Background(), group1)
|
|
require.Nil(t, err, fmt.Sprintf("group save got unexpected error: %s", err))
|
|
|
|
gid, err = idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("group id unexpected error: %s", err))
|
|
group2 := users.Group{
|
|
ID: gid,
|
|
Name: groupName + "TestAssignUser2",
|
|
OwnerID: user.ID,
|
|
}
|
|
|
|
g2, err := repo.Save(context.Background(), group2)
|
|
require.Nil(t, err, fmt.Sprintf("group save got unexpected error: %s", err))
|
|
|
|
gid, err = idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("group id generating error: %s", err))
|
|
g3 := users.Group{
|
|
ID: gid,
|
|
}
|
|
|
|
cases := []struct {
|
|
desc string
|
|
group users.Group
|
|
err error
|
|
}{
|
|
{
|
|
desc: "assign user to existing group",
|
|
group: g1,
|
|
err: nil,
|
|
},
|
|
{
|
|
desc: "assign user to another existing group",
|
|
group: g2,
|
|
err: nil,
|
|
},
|
|
{
|
|
desc: "assign user to non existing group",
|
|
group: g3,
|
|
err: users.ErrNotFound,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
err := repo.Assign(context.Background(), user.ID, tc.group.ID)
|
|
assert.True(t, errors.Contains(err, tc.err), fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
|
|
}
|
|
|
|
func TestUnassignUser(t *testing.T) {
|
|
dbMiddleware := postgres.NewDatabase(db)
|
|
repo := postgres.NewGroupRepo(dbMiddleware)
|
|
userRepo := postgres.NewUserRepo(dbMiddleware)
|
|
|
|
uid, err := idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("got unexpected error: %s", err))
|
|
user := users.User{
|
|
ID: uid,
|
|
Email: "UnassignUser1@mainflux.com",
|
|
Password: password,
|
|
}
|
|
|
|
_, err = userRepo.Save(context.Background(), user)
|
|
require.Nil(t, err, fmt.Sprintf("save got unexpected error: %s", err))
|
|
|
|
user1, err := userRepo.RetrieveByEmail(context.Background(), user.Email)
|
|
require.Nil(t, err, fmt.Sprintf("retrieve got unexpected error: %s", err))
|
|
|
|
uid, err = idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("got unexpected error: %s", err))
|
|
user = users.User{
|
|
ID: uid,
|
|
Email: "UnassignUser2@mainflux.com",
|
|
Password: password,
|
|
}
|
|
|
|
_, err = userRepo.Save(context.Background(), user)
|
|
require.Nil(t, err, fmt.Sprintf("save got unexpected error: %s", err))
|
|
|
|
user2, err := userRepo.RetrieveByEmail(context.Background(), user.Email)
|
|
require.Nil(t, err, fmt.Sprintf("retrieve got unexpected error: %s", err))
|
|
|
|
gid, err := idProvider.ID()
|
|
require.Nil(t, err, fmt.Sprintf("group id unexpected error: %s", err))
|
|
group1 := users.Group{
|
|
ID: gid,
|
|
Name: groupName + "UnassignUser1",
|
|
OwnerID: user.ID,
|
|
}
|
|
|
|
g1, err := repo.Save(context.Background(), group1)
|
|
require.Nil(t, err, fmt.Sprintf("group save got unexpected error: %s", err))
|
|
|
|
err = repo.Assign(context.Background(), user1.ID, group1.ID)
|
|
require.Nil(t, err, fmt.Sprintf("failed to assign user: %s", err))
|
|
|
|
cases := []struct {
|
|
desc string
|
|
group users.Group
|
|
user users.User
|
|
err error
|
|
}{
|
|
{desc: "remove user from a group", group: g1, user: user1, err: nil},
|
|
{desc: "remove already removed user from a group", group: g1, user: user1, err: nil},
|
|
{desc: "remove non existing user from a group", group: g1, user: user2, err: nil},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
err := repo.Unassign(context.Background(), tc.user.ID, tc.group.ID)
|
|
assert.True(t, errors.Contains(err, tc.err), fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
|
|
}
|