mirror of
https://github.com/idanoo/autobrr
synced 2025-07-23 08:49:13 +00:00

* feat(backend): added change password api endpoint. * feat(web): added profile UI to change password. I think we can change the username too, but I don't know if we should for now disabled the username field. * refactor: don't leak username or password. * refactor: protect the route. * generic * feat: add ChangeUsername * fix(tests): speculative fix for TestUserRepo_Update * Revert "feat: add ChangeUsername" This reverts commit d4c1645002883a278aa45dec3c8c19fa1cc75d9b. * refactor into 1 endpoint that handles both * feat: added option to change username as well. :pain: * refactor: frontend * refactor: function names in backend I think this makes it more clear what their function is * fix: change to 2 cols with separator * refactor: update user * fix: test db create user --------- Co-authored-by: Kyle Sanderson <kyle.leet@gmail.com> Co-authored-by: soup <soup@r4tio.dev> Co-authored-by: martylukyy <35452459+martylukyy@users.noreply.github.com> Co-authored-by: ze0s <ze0s@riseup.net>
165 lines
3.9 KiB
Go
165 lines
3.9 KiB
Go
package database
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/autobrr/autobrr/internal/domain"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func getMockUser() domain.User {
|
|
return domain.User{
|
|
ID: 0,
|
|
Username: "AkenoHimejima",
|
|
Password: "password",
|
|
}
|
|
}
|
|
|
|
func TestUserRepo_Store(t *testing.T) {
|
|
for dbType, db := range testDBs {
|
|
log := setupLoggerForTest()
|
|
|
|
repo := NewUserRepo(log, db)
|
|
|
|
userMockData := getMockUser()
|
|
|
|
t.Run(fmt.Sprintf("StoreUser_Succeeds [%s]", dbType), func(t *testing.T) {
|
|
// Execute
|
|
err := repo.Store(context.Background(), domain.CreateUserRequest{
|
|
Username: userMockData.Username,
|
|
Password: userMockData.Password,
|
|
})
|
|
|
|
// Verify
|
|
assert.NoError(t, err)
|
|
|
|
// Cleanup
|
|
_ = repo.Delete(context.Background(), userMockData.Username)
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestUserRepo_Update(t *testing.T) {
|
|
for dbType, db := range testDBs {
|
|
log := setupLoggerForTest()
|
|
|
|
repo := NewUserRepo(log, db)
|
|
|
|
user := getMockUser()
|
|
err := repo.Store(context.Background(), domain.CreateUserRequest{
|
|
Username: user.Username,
|
|
Password: user.Password,
|
|
})
|
|
assert.NoError(t, err)
|
|
|
|
storedUser, err := repo.FindByUsername(context.Background(), user.Username)
|
|
assert.NoError(t, err)
|
|
user.ID = storedUser.ID
|
|
|
|
t.Run(fmt.Sprintf("UpdateUser_Succeeds [%s]", dbType), func(t *testing.T) {
|
|
// Update the user
|
|
newPassword := "newPassword123"
|
|
user.Password = newPassword
|
|
req := domain.UpdateUserRequest{
|
|
UsernameCurrent: user.Username,
|
|
PasswordNewHash: newPassword,
|
|
}
|
|
err := repo.Update(context.Background(), req)
|
|
assert.NoError(t, err)
|
|
|
|
// Verify
|
|
updatedUser, err := repo.FindByUsername(context.Background(), user.Username)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, newPassword, updatedUser.Password)
|
|
|
|
// Cleanup
|
|
_ = repo.Delete(context.Background(), updatedUser.Username)
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestUserRepo_GetUserCount(t *testing.T) {
|
|
for dbType, db := range testDBs {
|
|
log := setupLoggerForTest()
|
|
|
|
repo := NewUserRepo(log, db)
|
|
|
|
t.Run(fmt.Sprintf("GetUserCount_Succeeds [%s]", dbType), func(t *testing.T) {
|
|
// Setup
|
|
initialCount, err := repo.GetUserCount(context.Background())
|
|
assert.NoError(t, err)
|
|
|
|
user := getMockUser()
|
|
err = repo.Store(context.Background(), domain.CreateUserRequest{
|
|
Username: user.Username,
|
|
Password: user.Password,
|
|
})
|
|
assert.NoError(t, err)
|
|
|
|
// Verify
|
|
updatedCount, err := repo.GetUserCount(context.Background())
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, initialCount+1, updatedCount)
|
|
|
|
// Cleanup
|
|
_ = repo.Delete(context.Background(), user.Username)
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestUserRepo_FindByUsername(t *testing.T) {
|
|
for dbType, db := range testDBs {
|
|
log := setupLoggerForTest()
|
|
|
|
repo := NewUserRepo(log, db)
|
|
|
|
userMockData := getMockUser()
|
|
|
|
t.Run(fmt.Sprintf("FindByUsername_Succeeds [%s]", dbType), func(t *testing.T) {
|
|
// Execute
|
|
err := repo.Store(context.Background(), domain.CreateUserRequest{
|
|
Username: userMockData.Username,
|
|
Password: userMockData.Password,
|
|
})
|
|
assert.NoError(t, err)
|
|
|
|
// Verify
|
|
user, err := repo.FindByUsername(context.Background(), userMockData.Username)
|
|
assert.NoError(t, err)
|
|
assert.NotNil(t, user)
|
|
assert.Equal(t, userMockData.Username, user.Username)
|
|
|
|
// Cleanup
|
|
_ = repo.Delete(context.Background(), userMockData.Username)
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestUserRepo_Delete(t *testing.T) {
|
|
for dbType, db := range testDBs {
|
|
log := setupLoggerForTest()
|
|
|
|
repo := NewUserRepo(log, db)
|
|
|
|
user := getMockUser()
|
|
err := repo.Store(context.Background(), domain.CreateUserRequest{
|
|
Username: user.Username,
|
|
Password: user.Password,
|
|
})
|
|
assert.NoError(t, err)
|
|
|
|
t.Run(fmt.Sprintf("DeleteUser_Succeeds [%s]", dbType), func(t *testing.T) {
|
|
// Setup
|
|
err := repo.Delete(context.Background(), user.Username)
|
|
assert.NoError(t, err)
|
|
|
|
// Verify
|
|
_, err = repo.FindByUsername(context.Background(), user.Username)
|
|
assert.Error(t, err)
|
|
assert.Equal(t, domain.ErrRecordNotFound, err)
|
|
})
|
|
}
|
|
}
|