git-bug/identity/identity_actions_test.go
Michael Muré 88ad7e606f
repository: remove tie to Bug, improved and reusable testing
- allow the creation of arbitrary Lamport clocks, freeing the way to new entities and removing Bug specific (upper layer) code.
- generalize the memory-only and persisted Lamport clocks behind a common interface
- rework the tests to provide reusable testing code for a Repo, a Clock, a Config, opening a path to add a new Repo implementation more easily
- test previously untested components with those new tests

Note: one problem found during this endeavor is that `identity.Version` also need to store one time + Lamport time for each other Entity (Bug, config, PR ...). This could possibly done without breaking change but it would be much easier to wait for https://github.com/MichaelMure/git-bug-migration to happen.
2020-06-26 19:14:22 +02:00

153 lines
3.1 KiB
Go

package identity
import (
"testing"
"github.com/stretchr/testify/require"
"github.com/MichaelMure/git-bug/repository"
)
func TestPushPull(t *testing.T) {
repoA, repoB, remote := repository.SetupReposAndRemote()
defer repository.CleanupTestRepos(repoA, repoB, remote)
identity1 := NewIdentity("name1", "email1")
err := identity1.Commit(repoA)
require.NoError(t, err)
// A --> remote --> B
_, err = Push(repoA, "origin")
require.NoError(t, err)
err = Pull(repoB, "origin")
require.NoError(t, err)
identities := allIdentities(t, ReadAllLocalIdentities(repoB))
if len(identities) != 1 {
t.Fatal("Unexpected number of bugs")
}
// B --> remote --> A
identity2 := NewIdentity("name2", "email2")
err = identity2.Commit(repoB)
require.NoError(t, err)
_, err = Push(repoB, "origin")
require.NoError(t, err)
err = Pull(repoA, "origin")
require.NoError(t, err)
identities = allIdentities(t, ReadAllLocalIdentities(repoA))
if len(identities) != 2 {
t.Fatal("Unexpected number of bugs")
}
// Update both
identity1.addVersionForTest(&Version{
name: "name1b",
email: "email1b",
})
err = identity1.Commit(repoA)
require.NoError(t, err)
identity2.addVersionForTest(&Version{
name: "name2b",
email: "email2b",
})
err = identity2.Commit(repoB)
require.NoError(t, err)
// A --> remote --> B
_, err = Push(repoA, "origin")
require.NoError(t, err)
err = Pull(repoB, "origin")
require.NoError(t, err)
identities = allIdentities(t, ReadAllLocalIdentities(repoB))
if len(identities) != 2 {
t.Fatal("Unexpected number of bugs")
}
// B --> remote --> A
_, err = Push(repoB, "origin")
require.NoError(t, err)
err = Pull(repoA, "origin")
require.NoError(t, err)
identities = allIdentities(t, ReadAllLocalIdentities(repoA))
if len(identities) != 2 {
t.Fatal("Unexpected number of bugs")
}
// Concurrent update
identity1.addVersionForTest(&Version{
name: "name1c",
email: "email1c",
})
err = identity1.Commit(repoA)
require.NoError(t, err)
identity1B, err := ReadLocal(repoB, identity1.Id())
require.NoError(t, err)
identity1B.addVersionForTest(&Version{
name: "name1concurrent",
email: "email1concurrent",
})
err = identity1B.Commit(repoB)
require.NoError(t, err)
// A --> remote --> B
_, err = Push(repoA, "origin")
require.NoError(t, err)
// Pulling a non-fast-forward update should fail
err = Pull(repoB, "origin")
require.Error(t, err)
identities = allIdentities(t, ReadAllLocalIdentities(repoB))
if len(identities) != 2 {
t.Fatal("Unexpected number of bugs")
}
// B --> remote --> A
// Pushing a non-fast-forward update should fail
_, err = Push(repoB, "origin")
require.Error(t, err)
err = Pull(repoA, "origin")
require.NoError(t, err)
identities = allIdentities(t, ReadAllLocalIdentities(repoA))
if len(identities) != 2 {
t.Fatal("Unexpected number of bugs")
}
}
func allIdentities(t testing.TB, identities <-chan StreamedIdentity) []*Identity {
var result []*Identity
for streamed := range identities {
if streamed.Err != nil {
t.Fatal(streamed.Err)
}
result = append(result, streamed.Identity)
}
return result
}