mirror of
https://github.com/usememos/memos.git
synced 2024-11-24 14:42:58 +03:00
feat: add test for user store (#1438)
This commit is contained in:
parent
0cddb358c1
commit
0baf6b0e19
@ -99,9 +99,8 @@ var (
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
st := store.New(db.DBInstance, profile)
|
store := store.New(db.DBInstance, profile)
|
||||||
|
if err := setup.Execute(ctx, store, hostUsername, hostPassword); err != nil {
|
||||||
if err := setup.Execute(ctx, st, hostUsername, hostPassword); err != nil {
|
|
||||||
fmt.Printf("failed to setup, error: %+v\n", err)
|
fmt.Printf("failed to setup, error: %+v\n", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -11,7 +11,7 @@ import (
|
|||||||
"github.com/usememos/memos/api"
|
"github.com/usememos/memos/api"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestSetupService_makeSureHostUserNotExists(t *testing.T) {
|
func TestSetupServiceMakeSureHostUserNotExists(t *testing.T) {
|
||||||
cc := map[string]struct {
|
cc := map[string]struct {
|
||||||
setupStore func(*storeMock)
|
setupStore func(*storeMock)
|
||||||
expectedErr string
|
expectedErr string
|
||||||
@ -71,7 +71,7 @@ func TestSetupService_makeSureHostUserNotExists(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSetupService_createUser(t *testing.T) {
|
func TestSetupServiceCreateUser(t *testing.T) {
|
||||||
expectedCreated := &api.UserCreate{
|
expectedCreated := &api.UserCreate{
|
||||||
Username: "demohero",
|
Username: "demohero",
|
||||||
Role: api.Host,
|
Role: api.Host,
|
||||||
@ -150,13 +150,13 @@ type storeMock struct {
|
|||||||
func (m *storeMock) FindUserList(ctx context.Context, find *api.UserFind) ([]*api.User, error) {
|
func (m *storeMock) FindUserList(ctx context.Context, find *api.UserFind) ([]*api.User, error) {
|
||||||
ret := m.Called(ctx, find)
|
ret := m.Called(ctx, find)
|
||||||
|
|
||||||
var uu []*api.User
|
var u []*api.User
|
||||||
ret1 := ret.Get(0)
|
ret1 := ret.Get(0)
|
||||||
if ret1 != nil {
|
if ret1 != nil {
|
||||||
uu = ret1.([]*api.User)
|
u = ret1.([]*api.User)
|
||||||
}
|
}
|
||||||
|
|
||||||
return uu, ret.Error(1)
|
return u, ret.Error(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *storeMock) CreateUser(ctx context.Context, create *api.UserCreate) (*api.User, error) {
|
func (m *storeMock) CreateUser(ctx context.Context, create *api.UserCreate) (*api.User, error) {
|
||||||
|
25
test/store/store.go
Normal file
25
test/store/store.go
Normal file
@ -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
|
||||||
|
}
|
47
test/store/user_test.go
Normal file
47
test/store/user_test.go
Normal file
@ -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))
|
||||||
|
}
|
22
test/test.go
Normal file
22
test/test.go
Normal file
@ -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
Block a user