git-bug/bug/op_edit_comment_test.go

102 lines
3.2 KiB
Go
Raw Normal View History

package bug
import (
2019-01-19 21:23:31 +03:00
"encoding/json"
"testing"
"time"
2019-02-16 19:32:30 +03:00
"github.com/stretchr/testify/require"
"github.com/MichaelMure/git-bug/identity"
"github.com/MichaelMure/git-bug/repository"
)
func TestEdit(t *testing.T) {
snapshot := Snapshot{}
repo := repository.NewMockRepo()
rene, err := identity.NewIdentity(repo, "René Descartes", "rene@descartes.fr")
require.NoError(t, err)
unix := time.Now().Unix()
create := NewCreateOp(rene, unix, "title", "create", nil)
create.Apply(&snapshot)
require.NoError(t, create.Id().Validate())
comment1 := NewAddCommentOp(rene, unix, "comment 1", nil)
comment1.Apply(&snapshot)
require.NoError(t, comment1.Id().Validate())
// add another unrelated op in between
setTitle := NewSetTitleOp(rene, unix, "edited title", "title")
setTitle.Apply(&snapshot)
comment2 := NewAddCommentOp(rene, unix, "comment 2", nil)
comment2.Apply(&snapshot)
require.NoError(t, comment2.Id().Validate())
edit := NewEditCommentOp(rene, unix, create.Id(), "create edited", nil)
edit.Apply(&snapshot)
2020-11-30 02:41:50 +03:00
require.Len(t, snapshot.Timeline, 4)
require.Len(t, snapshot.Timeline[0].(*CreateTimelineItem).History, 2)
require.Len(t, snapshot.Timeline[1].(*AddCommentTimelineItem).History, 1)
require.Len(t, snapshot.Timeline[3].(*AddCommentTimelineItem).History, 1)
require.Equal(t, snapshot.Comments[0].Message, "create edited")
require.Equal(t, snapshot.Comments[1].Message, "comment 1")
require.Equal(t, snapshot.Comments[2].Message, "comment 2")
edit2 := NewEditCommentOp(rene, unix, comment1.Id(), "comment 1 edited", nil)
edit2.Apply(&snapshot)
2020-11-30 02:41:50 +03:00
require.Len(t, snapshot.Timeline, 4)
require.Len(t, snapshot.Timeline[0].(*CreateTimelineItem).History, 2)
require.Len(t, snapshot.Timeline[1].(*AddCommentTimelineItem).History, 2)
require.Len(t, snapshot.Timeline[3].(*AddCommentTimelineItem).History, 1)
require.Equal(t, snapshot.Comments[0].Message, "create edited")
require.Equal(t, snapshot.Comments[1].Message, "comment 1 edited")
require.Equal(t, snapshot.Comments[2].Message, "comment 2")
edit3 := NewEditCommentOp(rene, unix, comment2.Id(), "comment 2 edited", nil)
edit3.Apply(&snapshot)
2020-11-30 02:41:50 +03:00
require.Len(t, snapshot.Timeline, 4)
require.Len(t, snapshot.Timeline[0].(*CreateTimelineItem).History, 2)
require.Len(t, snapshot.Timeline[1].(*AddCommentTimelineItem).History, 2)
require.Len(t, snapshot.Timeline[3].(*AddCommentTimelineItem).History, 2)
require.Equal(t, snapshot.Comments[0].Message, "create edited")
require.Equal(t, snapshot.Comments[1].Message, "comment 1 edited")
require.Equal(t, snapshot.Comments[2].Message, "comment 2 edited")
}
2019-01-19 21:23:31 +03:00
func TestEditCommentSerialize(t *testing.T) {
repo := repository.NewMockRepo()
rene, err := identity.NewIdentity(repo, "René Descartes", "rene@descartes.fr")
require.NoError(t, err)
2019-01-19 21:23:31 +03:00
unix := time.Now().Unix()
before := NewEditCommentOp(rene, unix, "target", "message", nil)
data, err := json.Marshal(before)
require.NoError(t, err)
2019-01-19 21:23:31 +03:00
var after EditCommentOperation
err = json.Unmarshal(data, &after)
require.NoError(t, err)
2019-01-19 21:23:31 +03:00
// enforce creating the ID
before.Id()
// Replace the identity stub with the real thing
require.Equal(t, rene.Id(), after.Author().Id())
after.Author_ = rene
require.Equal(t, before, &after)
2019-01-19 21:23:31 +03:00
}