2018-09-28 21:39:39 +03:00
|
|
|
package bug
|
2018-07-25 19:02:11 +03:00
|
|
|
|
|
|
|
import (
|
2018-09-28 21:39:39 +03:00
|
|
|
"github.com/MichaelMure/git-bug/repository"
|
2018-07-25 19:02:11 +03:00
|
|
|
"io/ioutil"
|
|
|
|
"log"
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func createRepo(bare bool) *repository.GitRepo {
|
|
|
|
dir, err := ioutil.TempDir("", "")
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2018-08-19 21:40:50 +03:00
|
|
|
// fmt.Println("Creating repo:", dir)
|
2018-07-25 19:02:11 +03:00
|
|
|
|
|
|
|
var creator func(string) (*repository.GitRepo, error)
|
|
|
|
|
|
|
|
if bare {
|
|
|
|
creator = repository.InitBareGitRepo
|
|
|
|
} else {
|
|
|
|
creator = repository.InitGitRepo
|
|
|
|
}
|
|
|
|
|
|
|
|
repo, err := creator(dir)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return repo
|
|
|
|
}
|
|
|
|
|
|
|
|
func cleanupRepo(repo repository.Repo) error {
|
|
|
|
path := repo.GetPath()
|
2018-08-19 21:40:50 +03:00
|
|
|
// fmt.Println("Cleaning repo:", path)
|
2018-07-25 19:02:11 +03:00
|
|
|
return os.RemoveAll(path)
|
|
|
|
}
|
|
|
|
|
2018-08-19 21:40:50 +03:00
|
|
|
func setupRepos(t testing.TB) (repoA, repoB, remote *repository.GitRepo) {
|
2018-07-25 19:02:11 +03:00
|
|
|
repoA = createRepo(false)
|
|
|
|
repoB = createRepo(false)
|
|
|
|
remote = createRepo(true)
|
|
|
|
|
|
|
|
remoteAddr := "file://" + remote.GetPath()
|
|
|
|
|
|
|
|
err := repoA.AddRemote("origin", remoteAddr)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
err = repoB.AddRemote("origin", remoteAddr)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2018-08-12 22:09:46 +03:00
|
|
|
|
|
|
|
return repoA, repoB, remote
|
2018-07-25 19:02:11 +03:00
|
|
|
}
|
|
|
|
|
2018-08-12 22:09:46 +03:00
|
|
|
func cleanupRepos(repoA, repoB, remote *repository.GitRepo) {
|
2018-07-25 19:02:11 +03:00
|
|
|
cleanupRepo(repoA)
|
|
|
|
cleanupRepo(repoB)
|
|
|
|
cleanupRepo(remote)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPushPull(t *testing.T) {
|
2018-08-12 22:09:46 +03:00
|
|
|
repoA, repoB, remote := setupRepos(t)
|
|
|
|
defer cleanupRepos(repoA, repoB, remote)
|
2018-07-25 19:02:11 +03:00
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bug1, err := Create(rene, unix, "bug1", "message")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug1.Commit(repoA)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
// A --> remote --> B
|
2018-09-28 21:39:39 +03:00
|
|
|
_, err = Push(repoA, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
err = Pull(repoB, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bugs := allBugs(t, ReadAllLocalBugs(repoB))
|
2018-07-25 19:02:11 +03:00
|
|
|
|
|
|
|
if len(bugs) != 1 {
|
|
|
|
t.Fatal("Unexpected number of bugs")
|
|
|
|
}
|
|
|
|
|
|
|
|
// B --> remote --> A
|
2018-09-28 21:39:39 +03:00
|
|
|
bug2, err := Create(rene, unix, "bug2", "message")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug2.Commit(repoB)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
_, err = Push(repoB, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
err = Pull(repoA, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bugs = allBugs(t, ReadAllLocalBugs(repoA))
|
2018-07-25 19:02:11 +03:00
|
|
|
|
|
|
|
if len(bugs) != 2 {
|
|
|
|
t.Fatal("Unexpected number of bugs")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-19 21:40:50 +03:00
|
|
|
func checkErr(t testing.TB, err error) {
|
2018-07-25 19:02:11 +03:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
func allBugs(t testing.TB, bugs <-chan StreamedBug) []*Bug {
|
|
|
|
var result []*Bug
|
2018-07-25 19:02:11 +03:00
|
|
|
for streamed := range bugs {
|
|
|
|
if streamed.Err != nil {
|
|
|
|
t.Fatal(streamed.Err)
|
|
|
|
}
|
|
|
|
result = append(result, streamed.Bug)
|
|
|
|
}
|
|
|
|
return result
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRebaseTheirs(t *testing.T) {
|
2018-08-19 21:40:50 +03:00
|
|
|
_RebaseTheirs(t)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkRebaseTheirs(b *testing.B) {
|
|
|
|
for n := 0; n < b.N; n++ {
|
|
|
|
_RebaseTheirs(b)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func _RebaseTheirs(t testing.TB) {
|
2018-08-12 22:09:46 +03:00
|
|
|
repoA, repoB, remote := setupRepos(t)
|
|
|
|
defer cleanupRepos(repoA, repoB, remote)
|
2018-07-25 19:02:11 +03:00
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bug1, err := Create(rene, unix, "bug1", "message")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug1.Commit(repoA)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
// A --> remote
|
2018-09-28 21:39:39 +03:00
|
|
|
_, err = Push(repoA, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
// remote --> B
|
2018-09-28 21:39:39 +03:00
|
|
|
err = Pull(repoB, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bug2, err := ReadLocalBug(repoB, bug1.Id())
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
AddComment(bug2, rene, unix, "message2")
|
|
|
|
AddComment(bug2, rene, unix, "message3")
|
|
|
|
AddComment(bug2, rene, unix, "message4")
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug2.Commit(repoB)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
// B --> remote
|
2018-09-28 21:39:39 +03:00
|
|
|
_, err = Push(repoB, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
// remote --> A
|
2018-09-28 21:39:39 +03:00
|
|
|
err = Pull(repoA, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bugs := allBugs(t, ReadAllLocalBugs(repoB))
|
2018-07-25 19:02:11 +03:00
|
|
|
|
|
|
|
if len(bugs) != 1 {
|
|
|
|
t.Fatal("Unexpected number of bugs")
|
|
|
|
}
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bug3, err := ReadLocalBug(repoA, bug1.Id())
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
if nbOps(bug3) != 4 {
|
|
|
|
t.Fatal("Unexpected number of operations")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRebaseOurs(t *testing.T) {
|
2018-08-19 21:40:50 +03:00
|
|
|
_RebaseOurs(t)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkRebaseOurs(b *testing.B) {
|
|
|
|
for n := 0; n < b.N; n++ {
|
|
|
|
_RebaseOurs(b)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func _RebaseOurs(t testing.TB) {
|
2018-08-12 22:09:46 +03:00
|
|
|
repoA, repoB, remote := setupRepos(t)
|
|
|
|
defer cleanupRepos(repoA, repoB, remote)
|
2018-07-25 19:02:11 +03:00
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bug1, err := Create(rene, unix, "bug1", "message")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug1.Commit(repoA)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
// A --> remote
|
2018-09-28 21:39:39 +03:00
|
|
|
_, err = Push(repoA, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
// remote --> B
|
2018-09-28 21:39:39 +03:00
|
|
|
err = Pull(repoB, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
AddComment(bug1, rene, unix, "message2")
|
|
|
|
AddComment(bug1, rene, unix, "message3")
|
|
|
|
AddComment(bug1, rene, unix, "message4")
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug1.Commit(repoA)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
AddComment(bug1, rene, unix, "message5")
|
|
|
|
AddComment(bug1, rene, unix, "message6")
|
|
|
|
AddComment(bug1, rene, unix, "message7")
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug1.Commit(repoA)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
AddComment(bug1, rene, unix, "message8")
|
|
|
|
AddComment(bug1, rene, unix, "message9")
|
|
|
|
AddComment(bug1, rene, unix, "message10")
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug1.Commit(repoA)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
// remote --> A
|
2018-09-28 21:39:39 +03:00
|
|
|
err = Pull(repoA, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bugs := allBugs(t, ReadAllLocalBugs(repoA))
|
2018-07-25 19:02:11 +03:00
|
|
|
|
|
|
|
if len(bugs) != 1 {
|
|
|
|
t.Fatal("Unexpected number of bugs")
|
|
|
|
}
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bug2, err := ReadLocalBug(repoA, bug1.Id())
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
if nbOps(bug2) != 10 {
|
|
|
|
t.Fatal("Unexpected number of operations")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
func nbOps(b *Bug) int {
|
|
|
|
it := NewOperationIterator(b)
|
2018-07-25 19:02:11 +03:00
|
|
|
counter := 0
|
|
|
|
for it.Next() {
|
|
|
|
counter++
|
|
|
|
}
|
|
|
|
return counter
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRebaseConflict(t *testing.T) {
|
2018-08-19 21:40:50 +03:00
|
|
|
_RebaseConflict(t)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkRebaseConflict(b *testing.B) {
|
|
|
|
for n := 0; n < b.N; n++ {
|
|
|
|
_RebaseConflict(b)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func _RebaseConflict(t testing.TB) {
|
2018-08-12 22:09:46 +03:00
|
|
|
repoA, repoB, remote := setupRepos(t)
|
|
|
|
defer cleanupRepos(repoA, repoB, remote)
|
2018-07-25 19:02:11 +03:00
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bug1, err := Create(rene, unix, "bug1", "message")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug1.Commit(repoA)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
// A --> remote
|
2018-09-28 21:39:39 +03:00
|
|
|
_, err = Push(repoA, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
// remote --> B
|
2018-09-28 21:39:39 +03:00
|
|
|
err = Pull(repoB, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
AddComment(bug1, rene, unix, "message2")
|
|
|
|
AddComment(bug1, rene, unix, "message3")
|
|
|
|
AddComment(bug1, rene, unix, "message4")
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug1.Commit(repoA)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
AddComment(bug1, rene, unix, "message5")
|
|
|
|
AddComment(bug1, rene, unix, "message6")
|
|
|
|
AddComment(bug1, rene, unix, "message7")
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug1.Commit(repoA)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
AddComment(bug1, rene, unix, "message8")
|
|
|
|
AddComment(bug1, rene, unix, "message9")
|
|
|
|
AddComment(bug1, rene, unix, "message10")
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug1.Commit(repoA)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bug2, err := ReadLocalBug(repoB, bug1.Id())
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
AddComment(bug2, rene, unix, "message11")
|
|
|
|
AddComment(bug2, rene, unix, "message12")
|
|
|
|
AddComment(bug2, rene, unix, "message13")
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug2.Commit(repoB)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
AddComment(bug2, rene, unix, "message14")
|
|
|
|
AddComment(bug2, rene, unix, "message15")
|
|
|
|
AddComment(bug2, rene, unix, "message16")
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug2.Commit(repoB)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
AddComment(bug2, rene, unix, "message17")
|
|
|
|
AddComment(bug2, rene, unix, "message18")
|
|
|
|
AddComment(bug2, rene, unix, "message19")
|
2018-09-13 13:43:47 +03:00
|
|
|
err = bug2.Commit(repoB)
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
// A --> remote
|
2018-09-28 21:39:39 +03:00
|
|
|
_, err = Push(repoA, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
// remote --> B
|
2018-09-28 21:39:39 +03:00
|
|
|
err = Pull(repoB, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bugs := allBugs(t, ReadAllLocalBugs(repoB))
|
2018-07-25 19:02:11 +03:00
|
|
|
|
|
|
|
if len(bugs) != 1 {
|
|
|
|
t.Fatal("Unexpected number of bugs")
|
|
|
|
}
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bug3, err := ReadLocalBug(repoB, bug1.Id())
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
if nbOps(bug3) != 19 {
|
|
|
|
t.Fatal("Unexpected number of operations")
|
|
|
|
}
|
|
|
|
|
|
|
|
// B --> remote
|
2018-09-28 21:39:39 +03:00
|
|
|
_, err = Push(repoB, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
// remote --> A
|
2018-09-28 21:39:39 +03:00
|
|
|
err = Pull(repoA, "origin")
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bugs = allBugs(t, ReadAllLocalBugs(repoA))
|
2018-07-25 19:02:11 +03:00
|
|
|
|
|
|
|
if len(bugs) != 1 {
|
|
|
|
t.Fatal("Unexpected number of bugs")
|
|
|
|
}
|
|
|
|
|
2018-09-28 21:39:39 +03:00
|
|
|
bug4, err := ReadLocalBug(repoA, bug1.Id())
|
2018-07-25 19:02:11 +03:00
|
|
|
checkErr(t, err)
|
|
|
|
|
|
|
|
if nbOps(bug4) != 19 {
|
|
|
|
t.Fatal("Unexpected number of operations")
|
|
|
|
}
|
|
|
|
}
|