2019-10-07 08:14:47 -06:00
|
|
|
// Copyright (c) Mainflux
|
2018-08-26 13:15:48 +02:00
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
2018-05-11 01:00:10 +02:00
|
|
|
package postgres_test
|
|
|
|
|
|
|
|
import (
|
2019-07-18 15:01:09 +02:00
|
|
|
"context"
|
2018-05-11 01:00:10 +02:00
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
|
2020-06-03 15:16:19 +02:00
|
|
|
"github.com/mainflux/mainflux/pkg/errors"
|
2020-06-04 22:29:16 +02:00
|
|
|
"github.com/mainflux/mainflux/pkg/uuid"
|
2018-05-11 01:00:10 +02:00
|
|
|
"github.com/mainflux/mainflux/users"
|
|
|
|
"github.com/mainflux/mainflux/users/postgres"
|
|
|
|
"github.com/stretchr/testify/assert"
|
2019-04-16 14:58:56 +02:00
|
|
|
"github.com/stretchr/testify/require"
|
2018-05-11 01:00:10 +02:00
|
|
|
)
|
|
|
|
|
2021-01-17 23:12:45 +01:00
|
|
|
var idProvider = uuid.New()
|
|
|
|
|
2018-05-11 01:00:10 +02:00
|
|
|
func TestUserSave(t *testing.T) {
|
|
|
|
email := "user-save@example.com"
|
|
|
|
|
2021-01-17 23:12:45 +01:00
|
|
|
uid, err := idProvider.ID()
|
2020-10-26 10:17:08 +01:00
|
|
|
require.Nil(t, err, fmt.Sprintf("unexpected error: %s", err))
|
2020-06-04 22:29:16 +02:00
|
|
|
|
2018-05-11 01:00:10 +02:00
|
|
|
cases := []struct {
|
|
|
|
desc string
|
|
|
|
user users.User
|
|
|
|
err error
|
|
|
|
}{
|
2019-04-16 14:58:56 +02:00
|
|
|
{
|
|
|
|
desc: "new user",
|
|
|
|
user: users.User{
|
2020-06-04 22:29:16 +02:00
|
|
|
ID: uid,
|
2019-04-16 14:58:56 +02:00
|
|
|
Email: email,
|
|
|
|
Password: "pass",
|
|
|
|
},
|
|
|
|
err: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
desc: "duplicate user",
|
|
|
|
user: users.User{
|
2020-06-04 22:29:16 +02:00
|
|
|
ID: uid,
|
2019-04-16 14:58:56 +02:00
|
|
|
Email: email,
|
|
|
|
Password: "pass",
|
|
|
|
},
|
|
|
|
err: users.ErrConflict,
|
|
|
|
},
|
2018-05-11 01:00:10 +02:00
|
|
|
}
|
|
|
|
|
2019-10-07 05:32:09 -06:00
|
|
|
dbMiddleware := postgres.NewDatabase(db)
|
2020-09-23 23:18:53 +02:00
|
|
|
repo := postgres.NewUserRepo(dbMiddleware)
|
2018-05-11 01:00:10 +02:00
|
|
|
|
|
|
|
for _, tc := range cases {
|
2020-09-23 23:18:53 +02:00
|
|
|
_, err := repo.Save(context.Background(), tc.user)
|
2019-11-20 14:43:41 +01:00
|
|
|
assert.True(t, errors.Contains(err, tc.err), fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
2018-05-11 01:00:10 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSingleUserRetrieval(t *testing.T) {
|
2019-10-07 05:32:09 -06:00
|
|
|
dbMiddleware := postgres.NewDatabase(db)
|
2020-09-23 23:18:53 +02:00
|
|
|
repo := postgres.NewUserRepo(dbMiddleware)
|
2020-06-04 22:29:16 +02:00
|
|
|
|
|
|
|
email := "user-retrieval@example.com"
|
|
|
|
|
2021-01-17 23:12:45 +01:00
|
|
|
uid, err := idProvider.ID()
|
2020-10-26 10:17:08 +01:00
|
|
|
require.Nil(t, err, fmt.Sprintf("unexpected error: %s", err))
|
2020-06-04 22:29:16 +02:00
|
|
|
|
|
|
|
user := users.User{
|
|
|
|
ID: uid,
|
2019-04-16 14:58:56 +02:00
|
|
|
Email: email,
|
|
|
|
Password: "pass",
|
2020-06-04 22:29:16 +02:00
|
|
|
}
|
|
|
|
|
2020-09-23 23:18:53 +02:00
|
|
|
_, err = repo.Save(context.Background(), user)
|
2019-04-16 14:58:56 +02:00
|
|
|
require.Nil(t, err, fmt.Sprintf("unexpected error: %s", err))
|
2018-05-11 01:00:10 +02:00
|
|
|
|
|
|
|
cases := map[string]struct {
|
|
|
|
email string
|
|
|
|
err error
|
|
|
|
}{
|
|
|
|
"existing user": {email, nil},
|
|
|
|
"non-existing user": {"unknown@example.com", users.ErrNotFound},
|
|
|
|
}
|
|
|
|
|
|
|
|
for desc, tc := range cases {
|
2020-06-04 22:29:16 +02:00
|
|
|
_, err := repo.RetrieveByEmail(context.Background(), tc.email)
|
2019-11-20 14:43:41 +01:00
|
|
|
assert.True(t, errors.Contains(err, tc.err), fmt.Sprintf("%s: expected %s got %s\n", desc, tc.err, err))
|
2018-05-11 01:00:10 +02:00
|
|
|
}
|
|
|
|
}
|
2020-09-23 23:18:53 +02:00
|
|
|
|
2020-10-26 10:17:08 +01:00
|
|
|
func TestRetrieveMembers(t *testing.T) {
|
2020-09-23 23:18:53 +02:00
|
|
|
dbMiddleware := postgres.NewDatabase(db)
|
|
|
|
groupRepo := postgres.NewGroupRepo(dbMiddleware)
|
|
|
|
userRepo := postgres.NewUserRepo(dbMiddleware)
|
|
|
|
var nUsers = uint64(10)
|
|
|
|
var usrs []users.User
|
|
|
|
for i := uint64(0); i < nUsers; i++ {
|
2021-01-17 23:12:45 +01:00
|
|
|
uid, err := idProvider.ID()
|
2020-10-26 10:17:08 +01:00
|
|
|
require.Nil(t, err, fmt.Sprintf("unexpected error: %s", err))
|
|
|
|
email := fmt.Sprintf("TestRetrieveMembers%d@example.com", i)
|
2020-09-23 23:18:53 +02:00
|
|
|
user := users.User{
|
|
|
|
ID: uid,
|
|
|
|
Email: email,
|
|
|
|
Password: "pass",
|
|
|
|
}
|
|
|
|
_, err = userRepo.Save(context.Background(), user)
|
|
|
|
require.Nil(t, err, fmt.Sprintf("saving user error: %s", err))
|
|
|
|
u, _ := userRepo.RetrieveByEmail(context.Background(), user.Email)
|
|
|
|
usrs = append(usrs, u)
|
|
|
|
}
|
2021-01-17 23:12:45 +01:00
|
|
|
uid, err := idProvider.ID()
|
2020-09-23 23:18:53 +02:00
|
|
|
require.Nil(t, err, fmt.Sprintf("user uuid error: %s", err))
|
|
|
|
group := users.Group{
|
|
|
|
ID: uid,
|
|
|
|
Name: "TestMembers",
|
|
|
|
}
|
|
|
|
|
|
|
|
g, err := groupRepo.Save(context.Background(), group)
|
|
|
|
require.Nil(t, err, fmt.Sprintf("group save got unexpected error: %s", err))
|
|
|
|
|
|
|
|
for _, u := range usrs {
|
|
|
|
err := groupRepo.Assign(context.Background(), u.ID, g.ID)
|
|
|
|
require.Nil(t, err, fmt.Sprintf("group user assign got unexpected error: %s", err))
|
|
|
|
}
|
|
|
|
|
|
|
|
cases := map[string]struct {
|
|
|
|
group string
|
|
|
|
offset uint64
|
|
|
|
limit uint64
|
|
|
|
size uint64
|
|
|
|
total uint64
|
|
|
|
metadata users.Metadata
|
|
|
|
}{
|
|
|
|
"retrieve all users for existing group": {
|
|
|
|
group: g.ID,
|
|
|
|
offset: 0,
|
|
|
|
limit: nUsers,
|
|
|
|
size: nUsers,
|
|
|
|
total: nUsers,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for desc, tc := range cases {
|
2020-10-26 10:17:08 +01:00
|
|
|
page, err := userRepo.RetrieveMembers(context.Background(), tc.group, tc.offset, tc.limit, tc.metadata)
|
2020-09-23 23:18:53 +02:00
|
|
|
size := uint64(len(usrs))
|
|
|
|
assert.Equal(t, tc.size, size, fmt.Sprintf("%s: expected size %d got %d\n", desc, tc.size, size))
|
|
|
|
assert.Equal(t, tc.total, page.Total, fmt.Sprintf("%s: expected total %d got %d\n", desc, tc.total, page.Total))
|
|
|
|
assert.Nil(t, err, fmt.Sprintf("%s: expected no error got %d\n", desc, err))
|
|
|
|
}
|
|
|
|
}
|
2020-10-26 10:17:08 +01:00
|
|
|
|
|
|
|
func TestRetrieveAll(t *testing.T) {
|
|
|
|
dbMiddleware := postgres.NewDatabase(db)
|
|
|
|
userRepo := postgres.NewUserRepo(dbMiddleware)
|
|
|
|
var nUsers = uint64(10)
|
|
|
|
|
|
|
|
for i := uint64(0); i < nUsers; i++ {
|
2021-01-17 23:12:45 +01:00
|
|
|
uid, err := idProvider.ID()
|
2020-10-26 10:17:08 +01:00
|
|
|
require.Nil(t, err, fmt.Sprintf("unexpected error: %s", err))
|
|
|
|
email := fmt.Sprintf("TestRetrieveAll%d@example.com", i)
|
|
|
|
user := users.User{
|
|
|
|
ID: uid,
|
|
|
|
Email: email,
|
|
|
|
Password: "pass",
|
|
|
|
}
|
|
|
|
_, err = userRepo.Save(context.Background(), user)
|
|
|
|
require.Nil(t, err, fmt.Sprintf("unexpected error: %s", err))
|
|
|
|
}
|
|
|
|
|
|
|
|
cases := map[string]struct {
|
|
|
|
email string
|
|
|
|
offset uint64
|
|
|
|
limit uint64
|
|
|
|
size uint64
|
|
|
|
total uint64
|
|
|
|
metadata users.Metadata
|
|
|
|
}{
|
|
|
|
"retrieve all users filtered by email": {
|
|
|
|
email: "All",
|
|
|
|
offset: 0,
|
|
|
|
limit: nUsers,
|
|
|
|
size: nUsers,
|
|
|
|
total: nUsers,
|
|
|
|
},
|
|
|
|
"retrieve all users by email with limit and offset": {
|
|
|
|
email: "All",
|
|
|
|
offset: 2,
|
|
|
|
limit: 5,
|
|
|
|
size: 5,
|
|
|
|
total: nUsers,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for desc, tc := range cases {
|
|
|
|
page, err := userRepo.RetrieveAll(context.Background(), tc.offset, tc.limit, tc.email, tc.metadata)
|
|
|
|
size := uint64(len(page.Users))
|
|
|
|
assert.Equal(t, tc.size, size, fmt.Sprintf("%s: expected size %d got %d\n", desc, tc.size, size))
|
|
|
|
assert.Nil(t, err, fmt.Sprintf("%s: expected no error got %d\n", desc, err))
|
|
|
|
}
|
|
|
|
}
|