mirror of https://github.com/usememos/memos
feat: add test for user store (#1438)
parent
0cddb358c1
commit
0baf6b0e19
@ -0,0 +1,25 @@
|
|||||||
|
package store_test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/usememos/memos/store"
|
||||||
|
"github.com/usememos/memos/store/db"
|
||||||
|
"github.com/usememos/memos/test"
|
||||||
|
|
||||||
|
// sqlite3 driver.
|
||||||
|
_ "github.com/mattn/go-sqlite3"
|
||||||
|
)
|
||||||
|
|
||||||
|
func NewTestingStore(ctx context.Context, t *testing.T) *store.Store {
|
||||||
|
profile := test.GetTestingProfile(t)
|
||||||
|
db := db.NewDB(profile)
|
||||||
|
if err := db.Open(ctx); err != nil {
|
||||||
|
fmt.Printf("failed to open db, error: %+v\n", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
store := store.New(db.DBInstance, profile)
|
||||||
|
return store
|
||||||
|
}
|
||||||
@ -0,0 +1,47 @@
|
|||||||
|
package store_test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
"github.com/usememos/memos/api"
|
||||||
|
"golang.org/x/crypto/bcrypt"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestUserStore(t *testing.T) {
|
||||||
|
ctx := context.Background()
|
||||||
|
store := NewTestingStore(ctx, t)
|
||||||
|
userCreate := &api.UserCreate{
|
||||||
|
Username: "test",
|
||||||
|
Role: api.Host,
|
||||||
|
Email: "test@test.com",
|
||||||
|
Nickname: "test_nickname",
|
||||||
|
Password: "test_password",
|
||||||
|
OpenID: "test_open_id",
|
||||||
|
}
|
||||||
|
passwordHash, err := bcrypt.GenerateFromPassword([]byte(userCreate.Password), bcrypt.DefaultCost)
|
||||||
|
require.NoError(t, err)
|
||||||
|
userCreate.PasswordHash = string(passwordHash)
|
||||||
|
user, err := store.CreateUser(ctx, userCreate)
|
||||||
|
require.NoError(t, err)
|
||||||
|
users, err := store.FindUserList(ctx, &api.UserFind{})
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, 1, len(users))
|
||||||
|
require.Equal(t, user, users[0])
|
||||||
|
userPatchNickname := "test_nickname_2"
|
||||||
|
userPatch := &api.UserPatch{
|
||||||
|
ID: user.ID,
|
||||||
|
Nickname: &userPatchNickname,
|
||||||
|
}
|
||||||
|
user, err = store.PatchUser(ctx, userPatch)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, userPatchNickname, user.Nickname)
|
||||||
|
err = store.DeleteUser(ctx, &api.UserDelete{
|
||||||
|
ID: user.ID,
|
||||||
|
})
|
||||||
|
require.NoError(t, err)
|
||||||
|
users, err = store.FindUserList(ctx, &api.UserFind{})
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, 0, len(users))
|
||||||
|
}
|
||||||
@ -0,0 +1,22 @@
|
|||||||
|
package test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/usememos/memos/server/profile"
|
||||||
|
"github.com/usememos/memos/server/version"
|
||||||
|
)
|
||||||
|
|
||||||
|
func GetTestingProfile(t *testing.T) *profile.Profile {
|
||||||
|
// Get a temporary directory for the test data.
|
||||||
|
dir := t.TempDir()
|
||||||
|
mode := "prod"
|
||||||
|
return &profile.Profile{
|
||||||
|
Mode: mode,
|
||||||
|
Port: 8082,
|
||||||
|
Data: dir,
|
||||||
|
DSN: fmt.Sprintf("%s/memos_%s.db", dir, mode),
|
||||||
|
Version: version.GetCurrentVersion(mode),
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue