aboutsummaryrefslogtreecommitdiffstats
path: root/entity/dag/entity_test.go
diff options
context:
space:
mode:
authorMichael Muré <batolettre@gmail.com>2021-02-14 10:06:16 +0100
committerMichael Muré <batolettre@gmail.com>2021-02-14 12:19:04 +0100
commit99b9dd84cb4b0cfd3eb1fd50b07c8b826eb52d19 (patch)
tree72a6328157d4b972d2480c785e575c25673b14f6 /entity/dag/entity_test.go
parent94f06cd54defa73f5e8b79345597279e454c78e6 (diff)
downloadgit-bug-99b9dd84cb4b0cfd3eb1fd50b07c8b826eb52d19.tar.gz
entity: support different author in staging operations
Diffstat (limited to 'entity/dag/entity_test.go')
-rw-r--r--entity/dag/entity_test.go47
1 files changed, 29 insertions, 18 deletions
diff --git a/entity/dag/entity_test.go b/entity/dag/entity_test.go
index 012c87aa..6d621bbe 100644
--- a/entity/dag/entity_test.go
+++ b/entity/dag/entity_test.go
@@ -7,7 +7,7 @@ import (
)
func TestWriteRead(t *testing.T) {
- repo, id1, id2, def := makeTestContext()
+ repo, id1, id2, resolver, def := makeTestContext()
entity := New(def)
require.False(t, entity.NeedCommit())
@@ -16,15 +16,34 @@ func TestWriteRead(t *testing.T) {
entity.Append(newOp2(id1, "bar"))
require.True(t, entity.NeedCommit())
- require.NoError(t, entity.CommitAdNeeded(repo))
+ require.NoError(t, entity.CommitAsNeeded(repo))
require.False(t, entity.NeedCommit())
entity.Append(newOp2(id2, "foobar"))
require.True(t, entity.NeedCommit())
- require.NoError(t, entity.CommitAdNeeded(repo))
+ require.NoError(t, entity.CommitAsNeeded(repo))
require.False(t, entity.NeedCommit())
- read, err := Read(def, repo, entity.Id())
+ read, err := Read(def, repo, resolver, entity.Id())
+ require.NoError(t, err)
+
+ assertEqualEntities(t, entity, read)
+}
+
+func TestWriteReadMultipleAuthor(t *testing.T) {
+ repo, id1, id2, resolver, def := makeTestContext()
+
+ entity := New(def)
+
+ entity.Append(newOp1(id1, "foo"))
+ entity.Append(newOp2(id2, "bar"))
+
+ require.NoError(t, entity.CommitAsNeeded(repo))
+
+ entity.Append(newOp2(id1, "foobar"))
+ require.NoError(t, entity.CommitAsNeeded(repo))
+
+ read, err := Read(def, repo, resolver, entity.Id())
require.NoError(t, err)
assertEqualEntities(t, entity, read)
@@ -34,23 +53,15 @@ func assertEqualEntities(t *testing.T, a, b *Entity) {
// testify doesn't support comparing functions and systematically fail if they are not nil
// so we have to set them to nil temporarily
- backOpUnA := a.Definition.operationUnmarshaler
- backOpUnB := b.Definition.operationUnmarshaler
-
- a.Definition.operationUnmarshaler = nil
- b.Definition.operationUnmarshaler = nil
-
- backIdResA := a.Definition.identityResolver
- backIdResB := b.Definition.identityResolver
+ backOpUnA := a.Definition.OperationUnmarshaler
+ backOpUnB := b.Definition.OperationUnmarshaler
- a.Definition.identityResolver = nil
- b.Definition.identityResolver = nil
+ a.Definition.OperationUnmarshaler = nil
+ b.Definition.OperationUnmarshaler = nil
defer func() {
- a.Definition.operationUnmarshaler = backOpUnA
- b.Definition.operationUnmarshaler = backOpUnB
- a.Definition.identityResolver = backIdResA
- b.Definition.identityResolver = backIdResB
+ a.Definition.OperationUnmarshaler = backOpUnA
+ b.Definition.OperationUnmarshaler = backOpUnB
}()
require.Equal(t, a, b)