mirror of
https://github.com/usememos/memos.git
synced 2025-06-05 22:09:59 +02:00
refactor: migrate memo to apiv1 (#1907)
* refactor: migrate memo to apiv1 * chore: update * chore: update * chore: update * chore: upate * chore: update * chore: update
This commit is contained in:
@@ -9,7 +9,6 @@ import (
|
||||
|
||||
"github.com/pkg/errors"
|
||||
"github.com/stretchr/testify/require"
|
||||
"github.com/usememos/memos/api"
|
||||
apiv1 "github.com/usememos/memos/api/v1"
|
||||
)
|
||||
|
||||
@@ -26,17 +25,17 @@ func TestMemoRelationServer(t *testing.T) {
|
||||
user, err := s.postAuthSignup(signup)
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, signup.Username, user.Username)
|
||||
memo, err := s.postMemoCreate(&api.CreateMemoRequest{
|
||||
memo, err := s.postMemoCreate(&apiv1.CreateMemoRequest{
|
||||
Content: "test memo",
|
||||
})
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, "test memo", memo.Content)
|
||||
memo2, err := s.postMemoCreate(&api.CreateMemoRequest{
|
||||
memo2, err := s.postMemoCreate(&apiv1.CreateMemoRequest{
|
||||
Content: "test memo2",
|
||||
RelationList: []*api.MemoRelationUpsert{
|
||||
RelationList: []*apiv1.UpsertMemoRelationRequest{
|
||||
{
|
||||
RelatedMemoID: memo.ID,
|
||||
Type: api.MemoRelationReference,
|
||||
Type: apiv1.MemoRelationReference,
|
||||
},
|
||||
},
|
||||
})
|
||||
@@ -46,14 +45,14 @@ func TestMemoRelationServer(t *testing.T) {
|
||||
require.NoError(t, err)
|
||||
require.Len(t, memoList, 2)
|
||||
require.Len(t, memo2.RelationList, 1)
|
||||
err = s.deleteMemoRelation(memo2.ID, memo.ID, api.MemoRelationReference)
|
||||
err = s.deleteMemoRelation(memo2.ID, memo.ID, apiv1.MemoRelationReference)
|
||||
require.NoError(t, err)
|
||||
memo2, err = s.getMemo(memo2.ID)
|
||||
require.NoError(t, err)
|
||||
require.Len(t, memo2.RelationList, 0)
|
||||
memoRelation, err := s.postMemoRelationUpsert(memo2.ID, &api.MemoRelationUpsert{
|
||||
memoRelation, err := s.postMemoRelationUpsert(memo2.ID, &apiv1.UpsertMemoRelationRequest{
|
||||
RelatedMemoID: memo.ID,
|
||||
Type: api.MemoRelationReference,
|
||||
Type: apiv1.MemoRelationReference,
|
||||
})
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, memo.ID, memoRelation.RelatedMemoID)
|
||||
@@ -62,13 +61,13 @@ func TestMemoRelationServer(t *testing.T) {
|
||||
require.Len(t, memo2.RelationList, 1)
|
||||
}
|
||||
|
||||
func (s *TestingServer) postMemoRelationUpsert(memoID int, memoRelationUpsert *api.MemoRelationUpsert) (*api.MemoRelation, error) {
|
||||
func (s *TestingServer) postMemoRelationUpsert(memoID int, memoRelationUpsert *apiv1.UpsertMemoRelationRequest) (*apiv1.MemoRelation, error) {
|
||||
rawData, err := json.Marshal(&memoRelationUpsert)
|
||||
if err != nil {
|
||||
return nil, errors.Wrap(err, "failed to marshal memo relation upsert")
|
||||
}
|
||||
reader := bytes.NewReader(rawData)
|
||||
body, err := s.post(fmt.Sprintf("/api/memo/%d/relation", memoID), reader, nil)
|
||||
body, err := s.post(fmt.Sprintf("/api/v1/memo/%d/relation", memoID), reader, nil)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@@ -79,17 +78,14 @@ func (s *TestingServer) postMemoRelationUpsert(memoID int, memoRelationUpsert *a
|
||||
return nil, errors.Wrap(err, "fail to read response body")
|
||||
}
|
||||
|
||||
type MemoCreateResponse struct {
|
||||
Data *api.MemoRelation `json:"data"`
|
||||
}
|
||||
res := new(MemoCreateResponse)
|
||||
if err = json.Unmarshal(buf.Bytes(), res); err != nil {
|
||||
memoRelation := &apiv1.MemoRelation{}
|
||||
if err = json.Unmarshal(buf.Bytes(), memoRelation); err != nil {
|
||||
return nil, errors.Wrap(err, "fail to unmarshal post memo relation upsert response")
|
||||
}
|
||||
return res.Data, nil
|
||||
return memoRelation, nil
|
||||
}
|
||||
|
||||
func (s *TestingServer) deleteMemoRelation(memoID int, relatedMemoID int, relationType api.MemoRelationType) error {
|
||||
_, err := s.delete(fmt.Sprintf("/api/memo/%d/relation/%d/type/%s", memoID, relatedMemoID, relationType), nil)
|
||||
func (s *TestingServer) deleteMemoRelation(memoID int, relatedMemoID int, relationType apiv1.MemoRelationType) error {
|
||||
_, err := s.delete(fmt.Sprintf("/api/v1/memo/%d/relation/%d/type/%s", memoID, relatedMemoID, relationType), nil)
|
||||
return err
|
||||
}
|
||||
|
@@ -9,7 +9,6 @@ import (
|
||||
|
||||
"github.com/pkg/errors"
|
||||
"github.com/stretchr/testify/require"
|
||||
"github.com/usememos/memos/api"
|
||||
apiv1 "github.com/usememos/memos/api/v1"
|
||||
)
|
||||
|
||||
@@ -26,7 +25,7 @@ func TestMemoServer(t *testing.T) {
|
||||
user, err := s.postAuthSignup(signup)
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, signup.Username, user.Username)
|
||||
memo, err := s.postMemoCreate(&api.CreateMemoRequest{
|
||||
memo, err := s.postMemoCreate(&apiv1.CreateMemoRequest{
|
||||
Content: "test memo",
|
||||
})
|
||||
require.NoError(t, err)
|
||||
@@ -35,20 +34,18 @@ func TestMemoServer(t *testing.T) {
|
||||
require.NoError(t, err)
|
||||
require.Len(t, memoList, 1)
|
||||
updatedContent := "updated memo"
|
||||
memo, err = s.patchMemo(&api.PatchMemoRequest{
|
||||
memo, err = s.patchMemo(&apiv1.PatchMemoRequest{
|
||||
ID: memo.ID,
|
||||
Content: &updatedContent,
|
||||
})
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, updatedContent, memo.Content)
|
||||
require.Equal(t, false, memo.Pinned)
|
||||
memo, err = s.postMemosOrganizer(&api.MemoOrganizerUpsert{
|
||||
MemoID: memo.ID,
|
||||
UserID: user.ID,
|
||||
_, err = s.postMemoOrganizer(memo.ID, &apiv1.UpsertMemoOrganizerRequest{
|
||||
Pinned: true,
|
||||
})
|
||||
require.NoError(t, err)
|
||||
memo, err = s.patchMemo(&api.PatchMemoRequest{
|
||||
memo, err = s.patchMemo(&apiv1.PatchMemoRequest{
|
||||
ID: memo.ID,
|
||||
Content: &updatedContent,
|
||||
})
|
||||
@@ -62,8 +59,8 @@ func TestMemoServer(t *testing.T) {
|
||||
require.Len(t, memoList, 0)
|
||||
}
|
||||
|
||||
func (s *TestingServer) getMemo(memoID int) (*api.MemoResponse, error) {
|
||||
body, err := s.get(fmt.Sprintf("/api/memo/%d", memoID), nil)
|
||||
func (s *TestingServer) getMemo(memoID int) (*apiv1.Memo, error) {
|
||||
body, err := s.get(fmt.Sprintf("/api/v1/memo/%d", memoID), nil)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@@ -74,18 +71,15 @@ func (s *TestingServer) getMemo(memoID int) (*api.MemoResponse, error) {
|
||||
return nil, errors.Wrap(err, "fail to read response body")
|
||||
}
|
||||
|
||||
type MemoCreateResponse struct {
|
||||
Data *api.MemoResponse `json:"data"`
|
||||
}
|
||||
res := new(MemoCreateResponse)
|
||||
if err = json.Unmarshal(buf.Bytes(), res); err != nil {
|
||||
memo := &apiv1.Memo{}
|
||||
if err = json.Unmarshal(buf.Bytes(), memo); err != nil {
|
||||
return nil, errors.Wrap(err, "fail to unmarshal get memo response")
|
||||
}
|
||||
return res.Data, nil
|
||||
return memo, nil
|
||||
}
|
||||
|
||||
func (s *TestingServer) getMemoList() ([]*api.MemoResponse, error) {
|
||||
body, err := s.get("/api/memo", nil)
|
||||
func (s *TestingServer) getMemoList() ([]*apiv1.Memo, error) {
|
||||
body, err := s.get("/api/v1/memo", nil)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@@ -96,23 +90,20 @@ func (s *TestingServer) getMemoList() ([]*api.MemoResponse, error) {
|
||||
return nil, errors.Wrap(err, "fail to read response body")
|
||||
}
|
||||
|
||||
type MemoCreateResponse struct {
|
||||
Data []*api.MemoResponse `json:"data"`
|
||||
}
|
||||
res := new(MemoCreateResponse)
|
||||
if err = json.Unmarshal(buf.Bytes(), res); err != nil {
|
||||
memoList := []*apiv1.Memo{}
|
||||
if err = json.Unmarshal(buf.Bytes(), &memoList); err != nil {
|
||||
return nil, errors.Wrap(err, "fail to unmarshal get memo list response")
|
||||
}
|
||||
return res.Data, nil
|
||||
return memoList, nil
|
||||
}
|
||||
|
||||
func (s *TestingServer) postMemoCreate(memoCreate *api.CreateMemoRequest) (*api.MemoResponse, error) {
|
||||
func (s *TestingServer) postMemoCreate(memoCreate *apiv1.CreateMemoRequest) (*apiv1.Memo, error) {
|
||||
rawData, err := json.Marshal(&memoCreate)
|
||||
if err != nil {
|
||||
return nil, errors.Wrap(err, "failed to marshal memo create")
|
||||
}
|
||||
reader := bytes.NewReader(rawData)
|
||||
body, err := s.post("/api/memo", reader, nil)
|
||||
body, err := s.post("/api/v1/memo", reader, nil)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@@ -123,23 +114,20 @@ func (s *TestingServer) postMemoCreate(memoCreate *api.CreateMemoRequest) (*api.
|
||||
return nil, errors.Wrap(err, "fail to read response body")
|
||||
}
|
||||
|
||||
type MemoCreateResponse struct {
|
||||
Data *api.MemoResponse `json:"data"`
|
||||
}
|
||||
res := new(MemoCreateResponse)
|
||||
if err = json.Unmarshal(buf.Bytes(), res); err != nil {
|
||||
memo := &apiv1.Memo{}
|
||||
if err = json.Unmarshal(buf.Bytes(), memo); err != nil {
|
||||
return nil, errors.Wrap(err, "fail to unmarshal post memo create response")
|
||||
}
|
||||
return res.Data, nil
|
||||
return memo, nil
|
||||
}
|
||||
|
||||
func (s *TestingServer) patchMemo(memoPatch *api.PatchMemoRequest) (*api.MemoResponse, error) {
|
||||
func (s *TestingServer) patchMemo(memoPatch *apiv1.PatchMemoRequest) (*apiv1.Memo, error) {
|
||||
rawData, err := json.Marshal(&memoPatch)
|
||||
if err != nil {
|
||||
return nil, errors.Wrap(err, "failed to marshal memo patch")
|
||||
}
|
||||
reader := bytes.NewReader(rawData)
|
||||
body, err := s.patch(fmt.Sprintf("/api/memo/%d", memoPatch.ID), reader, nil)
|
||||
body, err := s.patch(fmt.Sprintf("/api/v1/memo/%d", memoPatch.ID), reader, nil)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@@ -150,28 +138,25 @@ func (s *TestingServer) patchMemo(memoPatch *api.PatchMemoRequest) (*api.MemoRes
|
||||
return nil, errors.Wrap(err, "fail to read response body")
|
||||
}
|
||||
|
||||
type MemoPatchResponse struct {
|
||||
Data *api.MemoResponse `json:"data"`
|
||||
}
|
||||
res := new(MemoPatchResponse)
|
||||
if err = json.Unmarshal(buf.Bytes(), res); err != nil {
|
||||
memo := &apiv1.Memo{}
|
||||
if err = json.Unmarshal(buf.Bytes(), memo); err != nil {
|
||||
return nil, errors.Wrap(err, "fail to unmarshal patch memo response")
|
||||
}
|
||||
return res.Data, nil
|
||||
return memo, nil
|
||||
}
|
||||
|
||||
func (s *TestingServer) deleteMemo(memoID int) error {
|
||||
_, err := s.delete(fmt.Sprintf("/api/memo/%d", memoID), nil)
|
||||
_, err := s.delete(fmt.Sprintf("/api/v1/memo/%d", memoID), nil)
|
||||
return err
|
||||
}
|
||||
|
||||
func (s *TestingServer) postMemosOrganizer(memosOrganizer *api.MemoOrganizerUpsert) (*api.MemoResponse, error) {
|
||||
func (s *TestingServer) postMemoOrganizer(memoID int, memosOrganizer *apiv1.UpsertMemoOrganizerRequest) (*apiv1.Memo, error) {
|
||||
rawData, err := json.Marshal(&memosOrganizer)
|
||||
if err != nil {
|
||||
return nil, errors.Wrap(err, "failed to marshal memos organizer")
|
||||
}
|
||||
reader := bytes.NewReader(rawData)
|
||||
body, err := s.post(fmt.Sprintf("/api/memo/%d/organizer", memosOrganizer.MemoID), reader, nil)
|
||||
body, err := s.post(fmt.Sprintf("/api/v1/memo/%d/organizer", memoID), reader, nil)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@@ -182,12 +167,9 @@ func (s *TestingServer) postMemosOrganizer(memosOrganizer *api.MemoOrganizerUpse
|
||||
return nil, errors.Wrap(err, "fail to read response body")
|
||||
}
|
||||
|
||||
type MemoOrganizerResponse struct {
|
||||
Data *api.MemoResponse `json:"data"`
|
||||
}
|
||||
res := new(MemoOrganizerResponse)
|
||||
if err = json.Unmarshal(buf.Bytes(), res); err != nil {
|
||||
memo := &apiv1.Memo{}
|
||||
if err = json.Unmarshal(buf.Bytes(), memo); err != nil {
|
||||
return nil, errors.Wrap(err, "fail to unmarshal organizer memo create response")
|
||||
}
|
||||
return res.Data, err
|
||||
return memo, err
|
||||
}
|
||||
|
@@ -13,7 +13,7 @@ func TestMemoRelationStore(t *testing.T) {
|
||||
ts := NewTestingStore(ctx, t)
|
||||
user, err := createTestingHostUser(ctx, ts)
|
||||
require.NoError(t, err)
|
||||
memoCreate := &store.MemoMessage{
|
||||
memoCreate := &store.Memo{
|
||||
CreatorID: user.ID,
|
||||
Content: "test_content",
|
||||
Visibility: store.Public,
|
||||
@@ -21,7 +21,7 @@ func TestMemoRelationStore(t *testing.T) {
|
||||
memo, err := ts.CreateMemo(ctx, memoCreate)
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, memoCreate.Content, memo.Content)
|
||||
memo2Create := &store.MemoMessage{
|
||||
memo2Create := &store.Memo{
|
||||
CreatorID: user.ID,
|
||||
Content: "test_content_2",
|
||||
Visibility: store.Public,
|
||||
@@ -29,14 +29,14 @@ func TestMemoRelationStore(t *testing.T) {
|
||||
memo2, err := ts.CreateMemo(ctx, memo2Create)
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, memo2Create.Content, memo2.Content)
|
||||
memoRelationMessage := &store.MemoRelationMessage{
|
||||
memoRelationMessage := &store.MemoRelation{
|
||||
MemoID: memo.ID,
|
||||
RelatedMemoID: memo2.ID,
|
||||
Type: store.MemoRelationReference,
|
||||
}
|
||||
_, err = ts.UpsertMemoRelation(ctx, memoRelationMessage)
|
||||
require.NoError(t, err)
|
||||
memoRelation, err := ts.ListMemoRelations(ctx, &store.FindMemoRelationMessage{
|
||||
memoRelation, err := ts.ListMemoRelations(ctx, &store.FindMemoRelation{
|
||||
MemoID: &memo.ID,
|
||||
})
|
||||
require.NoError(t, err)
|
||||
@@ -44,11 +44,11 @@ func TestMemoRelationStore(t *testing.T) {
|
||||
require.Equal(t, memo2.ID, memoRelation[0].RelatedMemoID)
|
||||
require.Equal(t, memo.ID, memoRelation[0].MemoID)
|
||||
require.Equal(t, store.MemoRelationReference, memoRelation[0].Type)
|
||||
err = ts.DeleteMemo(ctx, &store.DeleteMemoMessage{
|
||||
err = ts.DeleteMemo(ctx, &store.DeleteMemo{
|
||||
ID: memo2.ID,
|
||||
})
|
||||
require.NoError(t, err)
|
||||
memoRelation, err = ts.ListMemoRelations(ctx, &store.FindMemoRelationMessage{
|
||||
memoRelation, err = ts.ListMemoRelations(ctx, &store.FindMemoRelation{
|
||||
MemoID: &memo.ID,
|
||||
})
|
||||
require.NoError(t, err)
|
||||
|
@@ -13,7 +13,7 @@ func TestMemoStore(t *testing.T) {
|
||||
ts := NewTestingStore(ctx, t)
|
||||
user, err := createTestingHostUser(ctx, ts)
|
||||
require.NoError(t, err)
|
||||
memoCreate := &store.MemoMessage{
|
||||
memoCreate := &store.Memo{
|
||||
CreatorID: user.ID,
|
||||
Content: "test_content",
|
||||
Visibility: store.Public,
|
||||
@@ -22,23 +22,23 @@ func TestMemoStore(t *testing.T) {
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, memoCreate.Content, memo.Content)
|
||||
memoPatchContent := "test_content_2"
|
||||
memoPatch := &store.UpdateMemoMessage{
|
||||
memoPatch := &store.UpdateMemo{
|
||||
ID: memo.ID,
|
||||
Content: &memoPatchContent,
|
||||
}
|
||||
err = ts.UpdateMemo(ctx, memoPatch)
|
||||
require.NoError(t, err)
|
||||
memo, err = ts.GetMemo(ctx, &store.FindMemoMessage{
|
||||
memo, err = ts.GetMemo(ctx, &store.FindMemo{
|
||||
ID: &memo.ID,
|
||||
})
|
||||
require.NoError(t, err)
|
||||
memoList, err := ts.ListMemos(ctx, &store.FindMemoMessage{
|
||||
memoList, err := ts.ListMemos(ctx, &store.FindMemo{
|
||||
CreatorID: &user.ID,
|
||||
})
|
||||
require.NoError(t, err)
|
||||
require.Equal(t, 1, len(memoList))
|
||||
require.Equal(t, memo, memoList[0])
|
||||
err = ts.DeleteMemo(ctx, &store.DeleteMemoMessage{
|
||||
err = ts.DeleteMemo(ctx, &store.DeleteMemo{
|
||||
ID: memo.ID,
|
||||
})
|
||||
require.NoError(t, err)
|
||||
|
@@ -11,7 +11,7 @@ import (
|
||||
func TestResourceStore(t *testing.T) {
|
||||
ctx := context.Background()
|
||||
ts := NewTestingStore(ctx, t)
|
||||
_, err := ts.CreateResourceV1(ctx, &store.Resource{
|
||||
_, err := ts.CreateResource(ctx, &store.Resource{
|
||||
CreatorID: 101,
|
||||
Filename: "test.epub",
|
||||
Blob: []byte("test"),
|
||||
@@ -49,11 +49,11 @@ func TestResourceStore(t *testing.T) {
|
||||
require.NoError(t, err)
|
||||
require.Nil(t, notFoundResource)
|
||||
|
||||
err = ts.DeleteResourceV1(ctx, &store.DeleteResource{
|
||||
err = ts.DeleteResource(ctx, &store.DeleteResource{
|
||||
ID: 1,
|
||||
})
|
||||
require.NoError(t, err)
|
||||
err = ts.DeleteResourceV1(ctx, &store.DeleteResource{
|
||||
err = ts.DeleteResource(ctx, &store.DeleteResource{
|
||||
ID: 2,
|
||||
})
|
||||
require.NoError(t, err)
|
||||
|
Reference in New Issue
Block a user