homebox/backend/internal/data/repo/repo_tokens_test.go

135 lines
3.2 KiB
Go
Raw Permalink Normal View History

2022-08-30 02:30:36 +00:00
package repo
import (
"context"
"testing"
"time"
"github.com/hay-kot/homebox/backend/pkgs/hasher"
2022-08-30 02:30:36 +00:00
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
2022-08-30 02:30:36 +00:00
)
func TestAuthTokenRepo_CreateToken(t *testing.T) {
2022-08-30 02:30:36 +00:00
ctx := context.Background()
user := userFactory()
2022-08-30 02:30:36 +00:00
userOut, err := tRepos.Users.Create(ctx, user)
require.NoError(t, err)
2022-08-30 02:30:36 +00:00
expiresAt := time.Now().Add(time.Hour)
generatedToken := hasher.GenerateToken()
token, err := tRepos.AuthTokens.CreateToken(ctx, UserAuthTokenCreate{
2022-08-30 02:30:36 +00:00
TokenHash: generatedToken.Hash,
ExpiresAt: expiresAt,
UserID: userOut.ID,
})
require.NoError(t, err)
assert.Equal(t, userOut.ID, token.UserID)
assert.Equal(t, expiresAt, token.ExpiresAt)
2022-08-30 02:30:36 +00:00
// Cleanup
require.NoError(t, tRepos.Users.Delete(ctx, userOut.ID))
_, err = tRepos.AuthTokens.DeleteAll(ctx)
require.NoError(t, err)
}
func TestAuthTokenRepo_DeleteToken(t *testing.T) {
ctx := context.Background()
user := userFactory()
userOut, err := tRepos.Users.Create(ctx, user)
require.NoError(t, err)
expiresAt := time.Now().Add(time.Hour)
generatedToken := hasher.GenerateToken()
_, err = tRepos.AuthTokens.CreateToken(ctx, UserAuthTokenCreate{
TokenHash: generatedToken.Hash,
ExpiresAt: expiresAt,
UserID: userOut.ID,
})
require.NoError(t, err)
// Delete token
err = tRepos.AuthTokens.DeleteToken(ctx, []byte(generatedToken.Raw))
require.NoError(t, err)
2022-08-30 02:30:36 +00:00
}
func TestAuthTokenRepo_GetUserByToken(t *testing.T) {
2022-08-30 02:30:36 +00:00
ctx := context.Background()
user := userFactory()
userOut, _ := tRepos.Users.Create(ctx, user)
2022-08-30 02:30:36 +00:00
expiresAt := time.Now().Add(time.Hour)
generatedToken := hasher.GenerateToken()
token, err := tRepos.AuthTokens.CreateToken(ctx, UserAuthTokenCreate{
2022-08-30 02:30:36 +00:00
TokenHash: generatedToken.Hash,
ExpiresAt: expiresAt,
UserID: userOut.ID,
})
require.NoError(t, err)
2022-08-31 03:21:18 +00:00
2022-08-30 02:30:36 +00:00
// Get User from token
foundUser, err := tRepos.AuthTokens.GetUserFromToken(ctx, token.TokenHash)
2022-08-30 02:30:36 +00:00
require.NoError(t, err)
assert.Equal(t, userOut.ID, foundUser.ID)
assert.Equal(t, userOut.Name, foundUser.Name)
assert.Equal(t, userOut.Email, foundUser.Email)
2022-08-30 02:30:36 +00:00
// Cleanup
require.NoError(t, tRepos.Users.Delete(ctx, userOut.ID))
_, err = tRepos.AuthTokens.DeleteAll(ctx)
require.NoError(t, err)
2022-08-30 02:30:36 +00:00
}
func TestAuthTokenRepo_PurgeExpiredTokens(t *testing.T) {
2022-08-30 02:30:36 +00:00
ctx := context.Background()
user := userFactory()
userOut, _ := tRepos.Users.Create(ctx, user)
2022-08-30 02:30:36 +00:00
createdTokens := []UserAuthToken{}
2022-08-30 02:30:36 +00:00
for i := 0; i < 5; i++ {
expiresAt := time.Now()
generatedToken := hasher.GenerateToken()
createdToken, err := tRepos.AuthTokens.CreateToken(ctx, UserAuthTokenCreate{
2022-08-30 02:30:36 +00:00
TokenHash: generatedToken.Hash,
ExpiresAt: expiresAt,
UserID: userOut.ID,
})
require.NoError(t, err)
assert.NotNil(t, createdToken)
2022-08-30 02:30:36 +00:00
createdTokens = append(createdTokens, createdToken)
}
// Purge expired tokens
tokensDeleted, err := tRepos.AuthTokens.PurgeExpiredTokens(ctx)
2022-08-30 02:30:36 +00:00
require.NoError(t, err)
assert.Equal(t, 5, tokensDeleted)
2022-08-30 02:30:36 +00:00
// Check if tokens are deleted
for _, token := range createdTokens {
_, err := tRepos.AuthTokens.GetUserFromToken(ctx, token.TokenHash)
require.Error(t, err)
2022-08-30 02:30:36 +00:00
}
// Cleanup
require.NoError(t, tRepos.Users.Delete(ctx, userOut.ID))
_, err = tRepos.AuthTokens.DeleteAll(ctx)
require.NoError(t, err)
2022-08-30 02:30:36 +00:00
}