2019-01-05 14:13:01 -06:00
|
|
|
package git
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2021-09-04 15:04:58 -05:00
|
|
|
func TestCreateCommitBuffer(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
repo := createTestRepo(t)
|
|
|
|
defer cleanupTestRepo(t, repo)
|
|
|
|
|
|
|
|
loc, err := time.LoadLocation("Europe/Berlin")
|
|
|
|
checkFatal(t, err)
|
|
|
|
sig := &Signature{
|
|
|
|
Name: "Rand Om Hacker",
|
|
|
|
Email: "random@hacker.com",
|
|
|
|
When: time.Date(2013, 03, 06, 14, 30, 0, 0, loc),
|
|
|
|
}
|
|
|
|
|
|
|
|
idx, err := repo.Index()
|
|
|
|
checkFatal(t, err)
|
|
|
|
err = idx.AddByPath("README")
|
|
|
|
checkFatal(t, err)
|
|
|
|
err = idx.Write()
|
|
|
|
checkFatal(t, err)
|
|
|
|
treeId, err := idx.WriteTree()
|
|
|
|
checkFatal(t, err)
|
|
|
|
|
|
|
|
message := "This is a commit\n"
|
|
|
|
tree, err := repo.LookupTree(treeId)
|
|
|
|
checkFatal(t, err)
|
|
|
|
|
|
|
|
for encoding, expected := range map[MessageEncoding]string{
|
|
|
|
MessageEncodingUTF8: `tree b7119b11e8ef7a1a5a34d3ac87f5b075228ac81e
|
|
|
|
author Rand Om Hacker <random@hacker.com> 1362576600 +0100
|
|
|
|
committer Rand Om Hacker <random@hacker.com> 1362576600 +0100
|
|
|
|
|
|
|
|
This is a commit
|
|
|
|
`,
|
|
|
|
MessageEncoding("ASCII"): `tree b7119b11e8ef7a1a5a34d3ac87f5b075228ac81e
|
|
|
|
author Rand Om Hacker <random@hacker.com> 1362576600 +0100
|
|
|
|
committer Rand Om Hacker <random@hacker.com> 1362576600 +0100
|
|
|
|
encoding ASCII
|
|
|
|
|
|
|
|
This is a commit
|
|
|
|
`,
|
|
|
|
} {
|
|
|
|
encoding := encoding
|
|
|
|
expected := expected
|
|
|
|
t.Run(string(encoding), func(t *testing.T) {
|
|
|
|
buf, err := repo.CreateCommitBuffer(sig, sig, encoding, message, tree)
|
|
|
|
checkFatal(t, err)
|
|
|
|
|
|
|
|
if expected != string(buf) {
|
|
|
|
t.Errorf("mismatched commit buffer, expected %v, got %v", expected, string(buf))
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-05 14:13:01 -06:00
|
|
|
func TestCreateCommitFromIds(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
repo := createTestRepo(t)
|
|
|
|
defer cleanupTestRepo(t, repo)
|
|
|
|
|
|
|
|
loc, err := time.LoadLocation("Europe/Berlin")
|
|
|
|
checkFatal(t, err)
|
|
|
|
sig := &Signature{
|
|
|
|
Name: "Rand Om Hacker",
|
|
|
|
Email: "random@hacker.com",
|
|
|
|
When: time.Date(2013, 03, 06, 14, 30, 0, 0, loc),
|
|
|
|
}
|
|
|
|
|
|
|
|
idx, err := repo.Index()
|
|
|
|
checkFatal(t, err)
|
|
|
|
err = idx.AddByPath("README")
|
|
|
|
checkFatal(t, err)
|
|
|
|
err = idx.Write()
|
|
|
|
checkFatal(t, err)
|
|
|
|
treeId, err := idx.WriteTree()
|
|
|
|
checkFatal(t, err)
|
|
|
|
|
|
|
|
message := "This is a commit\n"
|
|
|
|
tree, err := repo.LookupTree(treeId)
|
|
|
|
checkFatal(t, err)
|
|
|
|
expectedCommitId, err := repo.CreateCommit("HEAD", sig, sig, message, tree)
|
|
|
|
checkFatal(t, err)
|
|
|
|
|
|
|
|
commitId, err := repo.CreateCommitFromIds("", sig, sig, message, treeId)
|
|
|
|
checkFatal(t, err)
|
|
|
|
|
|
|
|
if !expectedCommitId.Equal(commitId) {
|
|
|
|
t.Errorf("mismatched commit ids, expected %v, got %v", expectedCommitId.String(), commitId.String())
|
|
|
|
}
|
|
|
|
}
|
2021-02-03 21:33:03 -06:00
|
|
|
|
|
|
|
func TestRepositorySetConfig(t *testing.T) {
|
|
|
|
repo := createTestRepo(t)
|
|
|
|
defer cleanupTestRepo(t, repo)
|
|
|
|
|
|
|
|
loc, err := time.LoadLocation("Europe/Berlin")
|
|
|
|
checkFatal(t, err)
|
|
|
|
sig := &Signature{
|
|
|
|
Name: "Rand Om Hacker",
|
|
|
|
Email: "random@hacker.com",
|
|
|
|
When: time.Date(2013, 03, 06, 14, 30, 0, 0, loc),
|
|
|
|
}
|
|
|
|
|
|
|
|
idx, err := repo.Index()
|
|
|
|
checkFatal(t, err)
|
|
|
|
err = idx.AddByPath("README")
|
|
|
|
|
|
|
|
treeId, err := idx.WriteTree()
|
|
|
|
checkFatal(t, err)
|
|
|
|
|
|
|
|
message := "This is a commit\n"
|
|
|
|
tree, err := repo.LookupTree(treeId)
|
|
|
|
checkFatal(t, err)
|
|
|
|
_, err = repo.CreateCommit("HEAD", sig, sig, message, tree)
|
|
|
|
checkFatal(t, err)
|
|
|
|
|
|
|
|
repoConfig, err := repo.Config()
|
|
|
|
checkFatal(t, err)
|
|
|
|
|
|
|
|
temp := Config{}
|
|
|
|
localConfig, err := temp.OpenLevel(repoConfig, ConfigLevelLocal)
|
|
|
|
checkFatal(t, err)
|
|
|
|
repoConfig = nil
|
|
|
|
|
|
|
|
err = repo.SetConfig(localConfig)
|
|
|
|
checkFatal(t, err)
|
|
|
|
|
|
|
|
configFieldName := "core.filemode"
|
|
|
|
err = localConfig.SetBool(configFieldName, true)
|
|
|
|
checkFatal(t, err)
|
|
|
|
|
|
|
|
localConfig = nil
|
|
|
|
|
|
|
|
repoConfig, err = repo.Config()
|
|
|
|
checkFatal(t, err)
|
|
|
|
|
|
|
|
result, err := repoConfig.LookupBool(configFieldName)
|
|
|
|
checkFatal(t, err)
|
|
|
|
if result != true {
|
|
|
|
t.Fatal("result must be true")
|
|
|
|
}
|
|
|
|
}
|
2021-04-03 18:52:34 -05:00
|
|
|
|
|
|
|
func TestRepositoryItemPath(t *testing.T) {
|
|
|
|
repo := createTestRepo(t)
|
|
|
|
defer cleanupTestRepo(t, repo)
|
|
|
|
|
|
|
|
gitDir, err := repo.ItemPath(RepositoryItemGitDir)
|
|
|
|
checkFatal(t, err)
|
|
|
|
if gitDir == "" {
|
|
|
|
t.Error("expected not empty gitDir")
|
|
|
|
}
|
|
|
|
}
|