git-bug/identity/identity_test.go

220 lines
4.9 KiB
Go
Raw Normal View History

2018-11-21 20:56:12 +03:00
package identity
import (
"testing"
"github.com/MichaelMure/git-bug/repository"
"github.com/stretchr/testify/assert"
2019-01-17 04:05:50 +03:00
"github.com/stretchr/testify/require"
2018-11-21 20:56:12 +03:00
)
2019-01-17 04:05:50 +03:00
func TestIdentityCommitLoad(t *testing.T) {
2018-11-21 20:56:12 +03:00
mockRepo := repository.NewMockRepoForTest()
// single version
identity := Identity{
2019-01-17 04:05:50 +03:00
Versions: []*Version{
2018-11-21 20:56:12 +03:00
{
Name: "René Descartes",
Email: "rene.descartes@example.com",
},
},
}
err := identity.Commit(mockRepo)
assert.Nil(t, err)
assert.NotEmpty(t, identity.id)
2019-01-17 04:05:50 +03:00
loaded, err := Read(mockRepo, identity.id)
assert.Nil(t, err)
commitsAreSet(t, loaded)
equivalentIdentity(t, &identity, loaded)
2018-11-21 20:56:12 +03:00
// multiple version
identity = Identity{
2019-01-17 04:05:50 +03:00
Versions: []*Version{
2018-11-21 20:56:12 +03:00
{
Time: 100,
Name: "René Descartes",
Email: "rene.descartes@example.com",
Keys: []Key{
{PubKey: "pubkeyA"},
},
},
{
Time: 200,
Name: "René Descartes",
Email: "rene.descartes@example.com",
Keys: []Key{
{PubKey: "pubkeyB"},
},
},
{
Time: 201,
Name: "René Descartes",
Email: "rene.descartes@example.com",
Keys: []Key{
{PubKey: "pubkeyC"},
},
},
},
}
err = identity.Commit(mockRepo)
assert.Nil(t, err)
assert.NotEmpty(t, identity.id)
2019-01-17 04:05:50 +03:00
loaded, err = Read(mockRepo, identity.id)
assert.Nil(t, err)
commitsAreSet(t, loaded)
equivalentIdentity(t, &identity, loaded)
2018-11-21 20:56:12 +03:00
// add more version
2019-01-17 04:05:50 +03:00
identity.AddVersion(&Version{
2018-11-21 20:56:12 +03:00
Time: 201,
Name: "René Descartes",
Email: "rene.descartes@example.com",
Keys: []Key{
{PubKey: "pubkeyD"},
},
})
2019-01-17 04:05:50 +03:00
identity.AddVersion(&Version{
2018-11-21 20:56:12 +03:00
Time: 300,
Name: "René Descartes",
Email: "rene.descartes@example.com",
Keys: []Key{
{PubKey: "pubkeyE"},
},
})
err = identity.Commit(mockRepo)
assert.Nil(t, err)
assert.NotEmpty(t, identity.id)
2019-01-17 04:05:50 +03:00
loaded, err = Read(mockRepo, identity.id)
assert.Nil(t, err)
commitsAreSet(t, loaded)
equivalentIdentity(t, &identity, loaded)
}
func commitsAreSet(t *testing.T, identity *Identity) {
for _, version := range identity.Versions {
assert.NotEmpty(t, version.commitHash)
}
}
func equivalentIdentity(t *testing.T, expected, actual *Identity) {
require.Equal(t, len(expected.Versions), len(actual.Versions))
for i, version := range expected.Versions {
actual.Versions[i].commitHash = version.commitHash
}
assert.Equal(t, expected, actual)
2018-11-21 20:56:12 +03:00
}
func TestIdentity_ValidKeysAtTime(t *testing.T) {
identity := Identity{
2019-01-17 04:05:50 +03:00
Versions: []*Version{
2018-11-21 20:56:12 +03:00
{
Time: 100,
Name: "René Descartes",
Email: "rene.descartes@example.com",
Keys: []Key{
{PubKey: "pubkeyA"},
},
},
{
Time: 200,
Name: "René Descartes",
Email: "rene.descartes@example.com",
Keys: []Key{
{PubKey: "pubkeyB"},
},
},
{
Time: 201,
Name: "René Descartes",
Email: "rene.descartes@example.com",
Keys: []Key{
{PubKey: "pubkeyC"},
},
},
{
Time: 201,
Name: "René Descartes",
Email: "rene.descartes@example.com",
Keys: []Key{
{PubKey: "pubkeyD"},
},
},
{
Time: 300,
Name: "René Descartes",
Email: "rene.descartes@example.com",
Keys: []Key{
{PubKey: "pubkeyE"},
},
},
},
}
assert.Nil(t, identity.ValidKeysAtTime(10))
assert.Equal(t, identity.ValidKeysAtTime(100), []Key{{PubKey: "pubkeyA"}})
assert.Equal(t, identity.ValidKeysAtTime(140), []Key{{PubKey: "pubkeyA"}})
assert.Equal(t, identity.ValidKeysAtTime(200), []Key{{PubKey: "pubkeyB"}})
assert.Equal(t, identity.ValidKeysAtTime(201), []Key{{PubKey: "pubkeyD"}})
assert.Equal(t, identity.ValidKeysAtTime(202), []Key{{PubKey: "pubkeyD"}})
assert.Equal(t, identity.ValidKeysAtTime(300), []Key{{PubKey: "pubkeyE"}})
assert.Equal(t, identity.ValidKeysAtTime(3000), []Key{{PubKey: "pubkeyE"}})
}
2019-01-17 04:05:50 +03:00
func TestMetadata(t *testing.T) {
mockRepo := repository.NewMockRepoForTest()
identity := NewIdentity("René Descartes", "rene.descartes@example.com")
identity.SetMetadata("key1", "value1")
assertHasKeyValue(t, identity.ImmutableMetadata(), "key1", "value1")
assertHasKeyValue(t, identity.MutableMetadata(), "key1", "value1")
err := identity.Commit(mockRepo)
assert.NoError(t, err)
assertHasKeyValue(t, identity.ImmutableMetadata(), "key1", "value1")
assertHasKeyValue(t, identity.MutableMetadata(), "key1", "value1")
// try override
identity.AddVersion(&Version{
Name: "René Descartes",
Email: "rene.descartes@example.com",
})
identity.SetMetadata("key1", "value2")
assertHasKeyValue(t, identity.ImmutableMetadata(), "key1", "value1")
assertHasKeyValue(t, identity.MutableMetadata(), "key1", "value2")
err = identity.Commit(mockRepo)
assert.NoError(t, err)
// reload
loaded, err := Read(mockRepo, identity.id)
assert.Nil(t, err)
assertHasKeyValue(t, loaded.ImmutableMetadata(), "key1", "value1")
assertHasKeyValue(t, loaded.MutableMetadata(), "key1", "value2")
}
func assertHasKeyValue(t *testing.T, metadata map[string]string, key, value string) {
val, ok := metadata[key]
assert.True(t, ok)
assert.Equal(t, val, value)
}