sessions/internal/bundb/user_test.go
Dawid Wysokiński 5b061dfef3
All checks were successful
continuous-integration/drone/push Build is passing
feat: add a new command - db user create (#4)
Reviewed-on: #4
2022-11-19 07:24:05 +00:00

63 lines
1.3 KiB
Go

package bundb_test
import (
"context"
"strings"
"testing"
"time"
"gitea.dwysokinski.me/twhelp/sessions/internal/bundb"
"gitea.dwysokinski.me/twhelp/sessions/internal/domain"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func TestUser_Create(t *testing.T) {
t.Parallel()
db := newDB(t)
fixture := loadFixtures(t, db)
repo := bundb.NewUser(db)
t.Run("OK", func(t *testing.T) {
t.Parallel()
params, err := domain.NewCreateUserParams("nameName")
require.Nil(t, err)
user, err := repo.Create(context.Background(), params)
assert.NoError(t, err)
assert.Greater(t, user.ID, int64(0))
assert.Equal(t, params.Name(), user.Name)
assert.WithinDuration(t, time.Now(), user.CreatedAt, time.Second)
})
t.Run("ERR: username must be unique", func(t *testing.T) {
t.Parallel()
name := fixture.user(t, "user-1").Name
names := []string{
name,
strings.ToUpper(name),
strings.ToLower(name),
}
for _, n := range names {
n := n
t.Run(n, func(t *testing.T) {
t.Parallel()
params, err := domain.NewCreateUserParams(n)
require.NoError(t, err)
user, err := repo.Create(context.Background(), params)
assert.ErrorIs(t, err, domain.UsernameAlreadyTakenError{
Name: n,
})
assert.Zero(t, user)
})
}
})
}