Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
C
canifa_note
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Vũ Hoàng Anh
canifa_note
Commits
5c519992
Unverified
Commit
5c519992
authored
May 13, 2023
by
boojack
Committed by
GitHub
May 13, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
chore: seed data for new user (#1655)
parent
e1c809d6
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
44 additions
and
7 deletions
+44
-7
user.go
store/user.go
+37
-0
memo_relation_test.go
test/server/memo_relation_test.go
+2
-2
memo_test.go
test/server/memo_test.go
+3
-3
memo_test.go
test/store/memo_test.go
+2
-2
No files found.
store/user.go
View file @
5c519992
...
...
@@ -10,6 +10,37 @@ import (
"github.com/usememos/memos/common"
)
func
(
s
*
Store
)
SeedDataForNewUser
(
ctx
context
.
Context
,
user
*
api
.
User
)
error
{
tx
,
err
:=
s
.
db
.
BeginTx
(
ctx
,
nil
)
if
err
!=
nil
{
return
FormatError
(
err
)
}
defer
tx
.
Rollback
()
// Create a memo for the user.
_
,
err
=
createMemoRaw
(
ctx
,
tx
,
&
api
.
MemoCreate
{
CreatorID
:
user
.
ID
,
Content
:
"#inbox Welcome to Memos!"
,
Visibility
:
api
.
Private
,
})
if
err
!=
nil
{
return
err
}
_
,
err
=
upsertTag
(
ctx
,
tx
,
&
api
.
TagUpsert
{
CreatorID
:
user
.
ID
,
Name
:
"inbox"
,
})
if
err
!=
nil
{
return
err
}
if
err
:=
tx
.
Commit
();
err
!=
nil
{
return
FormatError
(
err
)
}
return
nil
}
// userRaw is the store model for an User.
// Fields have exactly the same meanings as User.
type
userRaw
struct
{
...
...
@@ -63,6 +94,7 @@ func (s *Store) ComposeMemoCreator(ctx context.Context, memo *api.Memo) error {
}
return
nil
}
func
(
s
*
Store
)
CreateUser
(
ctx
context
.
Context
,
create
*
api
.
UserCreate
)
(
*
api
.
User
,
error
)
{
tx
,
err
:=
s
.
db
.
BeginTx
(
ctx
,
nil
)
if
err
!=
nil
{
...
...
@@ -81,6 +113,11 @@ func (s *Store) CreateUser(ctx context.Context, create *api.UserCreate) (*api.Us
s
.
userCache
.
Store
(
userRaw
.
ID
,
userRaw
)
user
:=
userRaw
.
toUser
()
if
err
:=
s
.
SeedDataForNewUser
(
ctx
,
user
);
err
!=
nil
{
return
nil
,
err
}
return
user
,
nil
}
...
...
test/server/memo_relation_test.go
View file @
5c519992
...
...
@@ -27,7 +27,7 @@ func TestMemoRelationServer(t *testing.T) {
require
.
Equal
(
t
,
signup
.
Username
,
user
.
Username
)
memoList
,
err
:=
s
.
getMemoList
()
require
.
NoError
(
t
,
err
)
require
.
Len
(
t
,
memoList
,
0
)
require
.
Len
(
t
,
memoList
,
1
)
memo
,
err
:=
s
.
postMemoCreate
(
&
api
.
MemoCreate
{
Content
:
"test memo"
,
})
...
...
@@ -46,7 +46,7 @@ func TestMemoRelationServer(t *testing.T) {
require
.
Equal
(
t
,
"test memo2"
,
memo2
.
Content
)
memoList
,
err
=
s
.
getMemoList
()
require
.
NoError
(
t
,
err
)
require
.
Len
(
t
,
memoList
,
2
)
require
.
Len
(
t
,
memoList
,
3
)
require
.
Len
(
t
,
memo2
.
RelationList
,
1
)
err
=
s
.
deleteMemoRelation
(
memo2
.
ID
,
memo
.
ID
,
api
.
MemoRelationReference
)
require
.
NoError
(
t
,
err
)
...
...
test/server/memo_test.go
View file @
5c519992
...
...
@@ -27,7 +27,7 @@ func TestMemoServer(t *testing.T) {
require
.
Equal
(
t
,
signup
.
Username
,
user
.
Username
)
memoList
,
err
:=
s
.
getMemoList
()
require
.
NoError
(
t
,
err
)
require
.
Len
(
t
,
memoList
,
0
)
require
.
Len
(
t
,
memoList
,
1
)
memo
,
err
:=
s
.
postMemoCreate
(
&
api
.
MemoCreate
{
Content
:
"test memo"
,
})
...
...
@@ -35,7 +35,7 @@ func TestMemoServer(t *testing.T) {
require
.
Equal
(
t
,
"test memo"
,
memo
.
Content
)
memoList
,
err
=
s
.
getMemoList
()
require
.
NoError
(
t
,
err
)
require
.
Len
(
t
,
memoList
,
1
)
require
.
Len
(
t
,
memoList
,
2
)
updatedContent
:=
"updated memo"
memo
,
err
=
s
.
patchMemo
(
&
api
.
MemoPatch
{
ID
:
memo
.
ID
,
...
...
@@ -63,7 +63,7 @@ func TestMemoServer(t *testing.T) {
require
.
NoError
(
t
,
err
)
memoList
,
err
=
s
.
getMemoList
()
require
.
NoError
(
t
,
err
)
require
.
Len
(
t
,
memoList
,
0
)
require
.
Len
(
t
,
memoList
,
1
)
}
func
(
s
*
TestingServer
)
getMemo
(
memoID
int
)
(
*
api
.
Memo
,
error
)
{
...
...
test/store/memo_test.go
View file @
5c519992
...
...
@@ -33,8 +33,8 @@ func TestMemoStore(t *testing.T) {
CreatorID
:
&
user
.
ID
,
})
require
.
NoError
(
t
,
err
)
require
.
Equal
(
t
,
1
,
len
(
memoList
))
require
.
Equal
(
t
,
memo
,
memoList
[
0
])
require
.
Equal
(
t
,
2
,
len
(
memoList
))
require
.
Equal
(
t
,
memo
,
memoList
[
1
])
err
=
store
.
DeleteMemo
(
ctx
,
&
api
.
MemoDelete
{
ID
:
memo
.
ID
,
})
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment