git-bug/bug/bug_test.go

187 lines
4.1 KiB
Go
Raw Normal View History

package bug
import (
2020-07-26 11:14:11 +03:00
"fmt"
2019-02-24 19:40:52 +03:00
"testing"
2019-02-16 19:32:30 +03:00
"time"
2020-07-26 11:14:11 +03:00
"github.com/stretchr/testify/require"
2019-02-16 19:32:30 +03:00
"github.com/MichaelMure/git-bug/identity"
"github.com/MichaelMure/git-bug/repository"
)
2018-07-13 18:07:24 +03:00
func TestBugId(t *testing.T) {
mockRepo := repository.NewMockRepoForTest()
bug1 := NewBug()
2019-02-16 19:32:30 +03:00
rene := identity.NewIdentity("René Descartes", "rene@descartes.fr")
err := rene.Commit(mockRepo)
require.NoError(t, err)
2019-02-16 19:32:30 +03:00
createOp := NewCreateOp(rene, time.Now().Unix(), "title", "message", nil)
bug1.Append(createOp)
err = bug1.Commit(mockRepo)
if err != nil {
t.Fatal(err)
2018-07-13 18:07:24 +03:00
}
bug1.Id()
2018-07-13 18:07:24 +03:00
}
2018-07-13 18:07:24 +03:00
func TestBugValidity(t *testing.T) {
mockRepo := repository.NewMockRepoForTest()
bug1 := NewBug()
2019-02-16 19:32:30 +03:00
rene := identity.NewIdentity("René Descartes", "rene@descartes.fr")
err := rene.Commit(mockRepo)
require.NoError(t, err)
2019-02-16 19:32:30 +03:00
createOp := NewCreateOp(rene, time.Now().Unix(), "title", "message", nil)
if bug1.Validate() == nil {
t.Fatal("Empty bug should be invalid")
}
bug1.Append(createOp)
if bug1.Validate() != nil {
2018-07-17 20:28:37 +03:00
t.Fatal("Bug with just a CreateOp should be valid")
}
err = bug1.Commit(mockRepo)
if err != nil {
t.Fatal(err)
}
bug1.Append(createOp)
if bug1.Validate() == nil {
2018-07-17 20:28:37 +03:00
t.Fatal("Bug with multiple CreateOp should be invalid")
}
err = bug1.Commit(mockRepo)
if err == nil {
t.Fatal("Invalid bug should not commit")
}
}
2020-07-26 11:14:11 +03:00
func TestBugCommitLoad(t *testing.T) {
repo := repository.NewMockRepoForTest()
bug1 := NewBug()
2019-02-16 19:32:30 +03:00
rene := identity.NewIdentity("René Descartes", "rene@descartes.fr")
err := rene.Commit(repo)
require.NoError(t, err)
2019-02-16 19:32:30 +03:00
createOp := NewCreateOp(rene, time.Now().Unix(), "title", "message", nil)
setTitleOp := NewSetTitleOp(rene, time.Now().Unix(), "title2", "title1")
addCommentOp := NewAddCommentOp(rene, time.Now().Unix(), "message2", nil)
bug1.Append(createOp)
bug1.Append(setTitleOp)
require.True(t, bug1.NeedCommit())
err = bug1.Commit(repo)
require.Nil(t, err)
require.False(t, bug1.NeedCommit())
bug2, err := ReadLocal(repo, bug1.Id())
require.NoError(t, err)
2019-02-07 00:06:42 +03:00
equivalentBug(t, bug1, bug2)
2019-02-07 00:06:42 +03:00
// add more op
bug1.Append(addCommentOp)
require.True(t, bug1.NeedCommit())
2019-02-07 00:06:42 +03:00
err = bug1.Commit(repo)
require.Nil(t, err)
require.False(t, bug1.NeedCommit())
2019-02-07 00:06:42 +03:00
bug3, err := ReadLocal(repo, bug1.Id())
require.NoError(t, err)
2019-02-07 00:06:42 +03:00
equivalentBug(t, bug1, bug3)
}
func equivalentBug(t *testing.T, expected, actual *Bug) {
require.Equal(t, len(expected.packs), len(actual.packs))
2019-02-07 00:06:42 +03:00
for i := range expected.packs {
for j := range expected.packs[i].Operations {
actual.packs[i].Operations[j].base().id = expected.packs[i].Operations[j].base().id
}
}
require.Equal(t, expected, actual)
}
2020-07-26 11:14:11 +03:00
func TestBugRemove(t *testing.T) {
repo := repository.CreateGoGitTestRepo(false)
remoteA := repository.CreateGoGitTestRepo(true)
remoteB := repository.CreateGoGitTestRepo(true)
2020-07-26 11:14:11 +03:00
defer repository.CleanupTestRepos(repo, remoteA, remoteB)
2020-12-05 05:08:54 +03:00
err := repo.AddRemote("remoteA", remoteA.GetLocalRemote())
2020-07-26 11:14:11 +03:00
require.NoError(t, err)
2020-12-05 05:08:54 +03:00
err = repo.AddRemote("remoteB", remoteB.GetLocalRemote())
2020-07-26 11:14:11 +03:00
require.NoError(t, err)
// generate a bunch of bugs
rene := identity.NewIdentity("René Descartes", "rene@descartes.fr")
err = rene.Commit(repo)
require.NoError(t, err)
for i := 0; i < 100; i++ {
b := NewBug()
createOp := NewCreateOp(rene, time.Now().Unix(), "title", fmt.Sprintf("message%v", i), nil)
b.Append(createOp)
err = b.Commit(repo)
require.NoError(t, err)
}
// and one more for testing
b := NewBug()
createOp := NewCreateOp(rene, time.Now().Unix(), "title", "message", nil)
b.Append(createOp)
err = b.Commit(repo)
require.NoError(t, err)
_, err = Push(repo, "remoteA")
require.NoError(t, err)
_, err = Push(repo, "remoteB")
require.NoError(t, err)
_, err = Fetch(repo, "remoteA")
require.NoError(t, err)
_, err = Fetch(repo, "remoteB")
require.NoError(t, err)
err = RemoveBug(repo, b.Id())
require.NoError(t, err)
_, err = ReadLocal(repo, b.Id())
2020-07-26 11:14:11 +03:00
require.Error(t, ErrBugNotExist, err)
_, err = ReadRemote(repo, "remoteA", b.Id())
2020-07-26 11:14:11 +03:00
require.Error(t, ErrBugNotExist, err)
_, err = ReadRemote(repo, "remoteB", b.Id())
2020-07-26 11:14:11 +03:00
require.Error(t, ErrBugNotExist, err)
2020-07-28 15:24:04 +03:00
ids, err := ListLocalIds(repo)
require.NoError(t, err)
require.Len(t, ids, 100)
2020-07-26 11:14:11 +03:00
}