2023-09-16 22:59:47 +00:00
|
|
|
package git
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/thomiceli/opengist/internal/config"
|
|
|
|
"os"
|
|
|
|
"os/exec"
|
|
|
|
"path"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestInitDeleteRepository(t *testing.T) {
|
2024-01-29 23:07:57 +00:00
|
|
|
SetupTest(t)
|
|
|
|
defer TeardownTest(t)
|
2023-09-16 22:59:47 +00:00
|
|
|
|
|
|
|
cmd := exec.Command("git", "rev-parse", "--is-bare-repository")
|
|
|
|
cmd.Dir = RepositoryPath("thomas", "gist1")
|
|
|
|
out, err := cmd.Output()
|
|
|
|
require.NoError(t, err, "Could not run git command")
|
|
|
|
require.Equal(t, "true", strings.TrimSpace(string(out)), "Repository is not bare")
|
|
|
|
|
|
|
|
_, err = os.Stat(path.Join(RepositoryPath("thomas", "gist1"), "git-daemon-export-ok"))
|
|
|
|
require.NoError(t, err, "git-daemon-export-ok file not found")
|
|
|
|
|
|
|
|
err = DeleteRepository("thomas", "gist1")
|
|
|
|
require.NoError(t, err, "Could not delete repository")
|
|
|
|
require.NoDirExists(t, RepositoryPath("thomas", "gist1"), "Repository should not exist")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCommits(t *testing.T) {
|
2024-01-29 23:07:57 +00:00
|
|
|
SetupTest(t)
|
|
|
|
defer TeardownTest(t)
|
2023-09-16 22:59:47 +00:00
|
|
|
|
|
|
|
hasNoCommits, err := HasNoCommits("thomas", "gist1")
|
|
|
|
require.NoError(t, err, "Could not check if repository has no commits")
|
|
|
|
require.True(t, hasNoCommits, "Repository should have no commits")
|
|
|
|
|
2024-01-29 23:07:57 +00:00
|
|
|
CommitToBare(t, "thomas", "gist1", nil)
|
2023-09-16 22:59:47 +00:00
|
|
|
|
|
|
|
hasNoCommits, err = HasNoCommits("thomas", "gist1")
|
|
|
|
require.NoError(t, err, "Could not check if repository has no commits")
|
|
|
|
require.False(t, hasNoCommits, "Repository should have commits")
|
|
|
|
|
|
|
|
nbCommits, err := CountCommits("thomas", "gist1")
|
|
|
|
require.NoError(t, err, "Could not count commits")
|
|
|
|
require.Equal(t, "1", nbCommits, "Repository should have 1 commit")
|
|
|
|
|
2024-01-29 23:07:57 +00:00
|
|
|
CommitToBare(t, "thomas", "gist1", nil)
|
2023-09-16 22:59:47 +00:00
|
|
|
nbCommits, err = CountCommits("thomas", "gist1")
|
|
|
|
require.NoError(t, err, "Could not count commits")
|
|
|
|
require.Equal(t, "2", nbCommits, "Repository should have 2 commits")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestContent(t *testing.T) {
|
2024-01-29 23:07:57 +00:00
|
|
|
SetupTest(t)
|
|
|
|
defer TeardownTest(t)
|
2023-09-16 22:59:47 +00:00
|
|
|
|
2024-01-29 23:07:57 +00:00
|
|
|
CommitToBare(t, "thomas", "gist1", map[string]string{
|
2023-09-16 22:59:47 +00:00
|
|
|
"my_file.txt": "I love Opengist\n",
|
|
|
|
"my_other_file.txt": `I really
|
|
|
|
hate Opengist`,
|
|
|
|
"rip.txt": "byebye",
|
|
|
|
})
|
|
|
|
|
|
|
|
files, err := GetFilesOfRepository("thomas", "gist1", "HEAD")
|
|
|
|
require.NoError(t, err, "Could not get files of repository")
|
|
|
|
require.Subset(t, []string{"my_file.txt", "my_other_file.txt", "rip.txt"}, files, "Files are not correct")
|
|
|
|
|
|
|
|
content, truncated, err := GetFileContent("thomas", "gist1", "HEAD", "my_file.txt", false)
|
|
|
|
require.NoError(t, err, "Could not get content")
|
|
|
|
require.False(t, truncated, "Content should not be truncated")
|
|
|
|
require.Equal(t, "I love Opengist\n", content, "Content is not correct")
|
|
|
|
|
|
|
|
content, truncated, err = GetFileContent("thomas", "gist1", "HEAD", "my_other_file.txt", false)
|
|
|
|
require.NoError(t, err, "Could not get content")
|
|
|
|
require.False(t, truncated, "Content should not be truncated")
|
|
|
|
require.Equal(t, "I really\nhate Opengist", content, "Content is not correct")
|
|
|
|
|
2024-01-29 23:07:57 +00:00
|
|
|
CommitToBare(t, "thomas", "gist1", map[string]string{
|
2023-09-16 22:59:47 +00:00
|
|
|
"my_renamed_file.txt": "I love Opengist\n",
|
|
|
|
"my_other_file.txt": `I really
|
|
|
|
like Opengist actually`,
|
|
|
|
"new_file.txt": "Wait now there is a new file",
|
|
|
|
})
|
|
|
|
|
|
|
|
files, err = GetFilesOfRepository("thomas", "gist1", "HEAD")
|
|
|
|
require.NoError(t, err, "Could not get files of repository")
|
|
|
|
require.Subset(t, []string{"my_renamed_file.txt", "my_other_file.txt", "new_file.txt"}, files, "Files are not correct")
|
|
|
|
|
|
|
|
content, truncated, err = GetFileContent("thomas", "gist1", "HEAD", "my_other_file.txt", false)
|
|
|
|
require.NoError(t, err, "Could not get content")
|
|
|
|
require.False(t, truncated, "Content should not be truncated")
|
|
|
|
require.Equal(t, "I really\nlike Opengist actually", content, "Content is not correct")
|
|
|
|
|
|
|
|
commits, err := GetLog("thomas", "gist1", 0)
|
|
|
|
require.NoError(t, err, "Could not get log")
|
|
|
|
require.Equal(t, 2, len(commits), "Commits count are not correct")
|
|
|
|
require.Regexp(t, "[a-f0-9]{40}", commits[0].Hash, "Commit ID is not correct")
|
|
|
|
require.Regexp(t, "[0-9]{10}", commits[0].Timestamp, "Commit timestamp is not correct")
|
|
|
|
require.Equal(t, "thomas", commits[0].AuthorName, "Commit author name is not correct")
|
|
|
|
require.Equal(t, "thomas@mail.com", commits[0].AuthorEmail, "Commit author email is not correct")
|
|
|
|
require.Equal(t, "4 files changed, 2 insertions, 2 deletions", commits[0].Changed, "Commit author name is not correct")
|
|
|
|
|
|
|
|
require.Contains(t, commits[0].Files, File{
|
|
|
|
Filename: "my_renamed_file.txt",
|
|
|
|
OldFilename: "my_file.txt",
|
|
|
|
Content: "",
|
|
|
|
Truncated: false,
|
|
|
|
IsCreated: false,
|
|
|
|
IsDeleted: false,
|
|
|
|
}, "File my_renamed_file.txt is not correct")
|
|
|
|
|
|
|
|
require.Contains(t, commits[0].Files, File{
|
|
|
|
Filename: "rip.txt",
|
|
|
|
OldFilename: "",
|
|
|
|
Content: `@@ -1 +0,0 @@
|
|
|
|
-byebye
|
|
|
|
\ No newline at end of file
|
|
|
|
`,
|
|
|
|
Truncated: false,
|
|
|
|
IsCreated: false,
|
|
|
|
IsDeleted: true,
|
|
|
|
}, "File rip.txt is not correct")
|
|
|
|
|
|
|
|
require.Contains(t, commits[0].Files, File{
|
|
|
|
Filename: "my_other_file.txt",
|
|
|
|
OldFilename: "",
|
|
|
|
Content: `@@ -1,2 +1,2 @@
|
|
|
|
I really
|
|
|
|
-hate Opengist
|
|
|
|
\ No newline at end of file
|
|
|
|
+like Opengist actually
|
|
|
|
\ No newline at end of file
|
|
|
|
`,
|
|
|
|
Truncated: false,
|
|
|
|
IsCreated: false,
|
|
|
|
IsDeleted: false,
|
|
|
|
}, "File my_other_file.txt is not correct")
|
|
|
|
|
|
|
|
require.Contains(t, commits[0].Files, File{
|
|
|
|
Filename: "new_file.txt",
|
|
|
|
OldFilename: "",
|
|
|
|
Content: `@@ -0,0 +1 @@
|
|
|
|
+Wait now there is a new file
|
|
|
|
\ No newline at end of file
|
|
|
|
`,
|
|
|
|
Truncated: false,
|
|
|
|
IsCreated: true,
|
|
|
|
IsDeleted: false,
|
|
|
|
}, "File new_file.txt is not correct")
|
|
|
|
|
|
|
|
commitsSkip1, err := GetLog("thomas", "gist1", 1)
|
|
|
|
require.NoError(t, err, "Could not get log")
|
|
|
|
require.Equal(t, commitsSkip1[0], commits[1], "Commits skips are not correct")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGitGc(t *testing.T) {
|
2024-01-29 23:07:57 +00:00
|
|
|
SetupTest(t)
|
|
|
|
defer TeardownTest(t)
|
2023-09-16 22:59:47 +00:00
|
|
|
|
|
|
|
err := GcRepos()
|
|
|
|
require.NoError(t, err, "Could not run git gc")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestFork(t *testing.T) {
|
2024-01-29 23:07:57 +00:00
|
|
|
SetupTest(t)
|
|
|
|
defer TeardownTest(t)
|
2023-09-16 22:59:47 +00:00
|
|
|
|
2024-01-29 23:07:57 +00:00
|
|
|
CommitToBare(t, "thomas", "gist1", map[string]string{
|
2023-09-16 22:59:47 +00:00
|
|
|
"my_file.txt": "I love Opengist\n",
|
|
|
|
})
|
|
|
|
|
|
|
|
err := ForkClone("thomas", "gist1", "thomas", "gist2")
|
|
|
|
require.NoError(t, err, "Could not fork repository")
|
|
|
|
|
|
|
|
files1, err := GetFilesOfRepository("thomas", "gist1", "HEAD")
|
|
|
|
require.NoError(t, err, "Could not get files of repository")
|
|
|
|
files2, err := GetFilesOfRepository("thomas", "gist2", "HEAD")
|
|
|
|
require.NoError(t, err, "Could not get files of repository")
|
|
|
|
|
|
|
|
require.Equal(t, files1, files2, "Files are not the same")
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestTruncate(t *testing.T) {
|
2024-01-29 23:07:57 +00:00
|
|
|
SetupTest(t)
|
|
|
|
defer TeardownTest(t)
|
2023-09-16 22:59:47 +00:00
|
|
|
|
2024-01-29 23:07:57 +00:00
|
|
|
CommitToBare(t, "thomas", "gist1", map[string]string{
|
2023-09-16 22:59:47 +00:00
|
|
|
"my_file.txt": "A",
|
|
|
|
})
|
|
|
|
|
|
|
|
content, truncated, err := GetFileContent("thomas", "gist1", "HEAD", "my_file.txt", true)
|
|
|
|
require.NoError(t, err, "Could not get content")
|
|
|
|
require.False(t, truncated, "Content should not be truncated")
|
|
|
|
require.Equal(t, 1, len(content), "Content size is not correct")
|
|
|
|
|
|
|
|
var builder strings.Builder
|
|
|
|
for i := 0; i < truncateLimit+10; i++ {
|
|
|
|
builder.WriteString("A")
|
|
|
|
}
|
|
|
|
str := builder.String()
|
2024-01-29 23:07:57 +00:00
|
|
|
CommitToBare(t, "thomas", "gist1", map[string]string{
|
2023-09-16 22:59:47 +00:00
|
|
|
"my_file.txt": str,
|
|
|
|
})
|
|
|
|
|
|
|
|
content, truncated, err = GetFileContent("thomas", "gist1", "HEAD", "my_file.txt", true)
|
|
|
|
require.NoError(t, err, "Could not get content")
|
|
|
|
require.True(t, truncated, "Content should be truncated")
|
|
|
|
require.Equal(t, truncateLimit, len(content), "Content size should be at truncate limit")
|
|
|
|
|
2024-01-29 23:07:57 +00:00
|
|
|
CommitToBare(t, "thomas", "gist1", map[string]string{
|
2023-09-16 22:59:47 +00:00
|
|
|
"my_file.txt": "AA\n" + str,
|
|
|
|
})
|
|
|
|
|
|
|
|
content, truncated, err = GetFileContent("thomas", "gist1", "HEAD", "my_file.txt", true)
|
|
|
|
require.NoError(t, err, "Could not get content")
|
|
|
|
require.True(t, truncated, "Content should be truncated")
|
|
|
|
require.Equal(t, 2, len(content), "Content size is not correct")
|
|
|
|
}
|
|
|
|
|
2023-12-27 16:30:42 +00:00
|
|
|
func TestGitInitBranchNames(t *testing.T) {
|
2024-01-29 23:07:57 +00:00
|
|
|
SetupTest(t)
|
|
|
|
defer TeardownTest(t)
|
2023-12-27 16:30:42 +00:00
|
|
|
|
|
|
|
cmd := exec.Command("git", "symbolic-ref", "HEAD")
|
|
|
|
cmd.Dir = RepositoryPath("thomas", "gist1")
|
|
|
|
out, err := cmd.Output()
|
|
|
|
require.NoError(t, err, "Could not run git command")
|
|
|
|
require.Equal(t, "refs/heads/master", strings.TrimSpace(string(out)), "Repository should have master branch as default")
|
|
|
|
|
|
|
|
config.C.GitDefaultBranch = "main"
|
|
|
|
|
|
|
|
err = InitRepository("thomas", "gist2")
|
|
|
|
require.NoError(t, err)
|
|
|
|
cmd = exec.Command("git", "symbolic-ref", "HEAD")
|
|
|
|
cmd.Dir = RepositoryPath("thomas", "gist2")
|
|
|
|
out, err = cmd.Output()
|
|
|
|
require.NoError(t, err, "Could not run git command")
|
|
|
|
require.Equal(t, "refs/heads/main", strings.TrimSpace(string(out)), "Repository should have main branch as default")
|
|
|
|
}
|