2019-03-27 10:33:00 +01:00
|
|
|
// Copyright 2018 The Gitea Authors. All rights reserved.
|
2022-11-27 19:20:29 +01:00
|
|
|
// SPDX-License-Identifier: MIT
|
2019-03-27 10:33:00 +01:00
|
|
|
|
|
|
|
package git
|
|
|
|
|
|
|
|
import (
|
|
|
|
"path/filepath"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
2024-08-09 04:40:45 +02:00
|
|
|
"github.com/stretchr/testify/require"
|
2019-03-27 10:33:00 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestRepository_GetBranches(t *testing.T) {
|
|
|
|
bareRepo1Path := filepath.Join(testReposDir, "repo1_bare")
|
2022-03-29 21:13:41 +02:00
|
|
|
bareRepo1, err := openRepositoryWithDefaultContext(bareRepo1Path)
|
2019-03-27 10:33:00 +01:00
|
|
|
assert.NoError(t, err)
|
2019-11-13 08:01:19 +01:00
|
|
|
defer bareRepo1.Close()
|
2019-03-27 10:33:00 +01:00
|
|
|
|
2021-12-08 20:08:16 +01:00
|
|
|
branches, countAll, err := bareRepo1.GetBranchNames(0, 2)
|
2021-02-03 20:06:13 +01:00
|
|
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Len(t, branches, 2)
|
|
|
|
assert.EqualValues(t, 3, countAll)
|
2022-09-14 14:11:24 +02:00
|
|
|
assert.ElementsMatch(t, []string{"master", "branch2"}, branches)
|
2021-02-03 20:06:13 +01:00
|
|
|
|
2021-12-08 20:08:16 +01:00
|
|
|
branches, countAll, err = bareRepo1.GetBranchNames(0, 0)
|
2019-03-27 10:33:00 +01:00
|
|
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Len(t, branches, 3)
|
2021-02-03 20:06:13 +01:00
|
|
|
assert.EqualValues(t, 3, countAll)
|
2022-09-14 14:11:24 +02:00
|
|
|
assert.ElementsMatch(t, []string{"master", "branch2", "branch1"}, branches)
|
2021-02-03 20:06:13 +01:00
|
|
|
|
2021-12-08 20:08:16 +01:00
|
|
|
branches, countAll, err = bareRepo1.GetBranchNames(5, 1)
|
2021-02-03 20:06:13 +01:00
|
|
|
|
|
|
|
assert.NoError(t, err)
|
2024-12-15 11:41:29 +01:00
|
|
|
assert.Empty(t, branches)
|
2021-02-03 20:06:13 +01:00
|
|
|
assert.EqualValues(t, 3, countAll)
|
|
|
|
assert.ElementsMatch(t, []string{}, branches)
|
2019-03-27 10:33:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkRepository_GetBranches(b *testing.B) {
|
|
|
|
bareRepo1Path := filepath.Join(testReposDir, "repo1_bare")
|
2022-03-29 21:13:41 +02:00
|
|
|
bareRepo1, err := openRepositoryWithDefaultContext(bareRepo1Path)
|
2019-03-27 10:33:00 +01:00
|
|
|
if err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
2019-11-13 08:01:19 +01:00
|
|
|
defer bareRepo1.Close()
|
2019-03-27 10:33:00 +01:00
|
|
|
|
|
|
|
for i := 0; i < b.N; i++ {
|
2021-12-08 20:08:16 +01:00
|
|
|
_, _, err := bareRepo1.GetBranchNames(0, 0)
|
2019-03-27 10:33:00 +01:00
|
|
|
if err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-05-07 19:05:52 +02:00
|
|
|
|
|
|
|
func TestGetRefsBySha(t *testing.T) {
|
|
|
|
bareRepo5Path := filepath.Join(testReposDir, "repo5_pulls")
|
|
|
|
bareRepo5, err := OpenRepository(DefaultContext, bareRepo5Path)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
defer bareRepo5.Close()
|
|
|
|
|
|
|
|
// do not exist
|
|
|
|
branches, err := bareRepo5.GetRefsBySha("8006ff9adbf0cb94da7dad9e537e53817f9fa5c0", "")
|
|
|
|
assert.NoError(t, err)
|
2024-12-15 11:41:29 +01:00
|
|
|
assert.Empty(t, branches)
|
2022-05-07 19:05:52 +02:00
|
|
|
|
|
|
|
// refs/pull/1/head
|
|
|
|
branches, err = bareRepo5.GetRefsBySha("c83380d7056593c51a699d12b9c00627bd5743e9", PullPrefix)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, []string{"refs/pull/1/head"}, branches)
|
|
|
|
|
|
|
|
branches, err = bareRepo5.GetRefsBySha("d8e0bbb45f200e67d9a784ce55bd90821af45ebd", BranchPrefix)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, []string{"refs/heads/master", "refs/heads/master-clone"}, branches)
|
|
|
|
|
|
|
|
branches, err = bareRepo5.GetRefsBySha("58a4bcc53ac13e7ff76127e0fb518b5262bf09af", BranchPrefix)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, []string{"refs/heads/test-patch-1"}, branches)
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkGetRefsBySha(b *testing.B) {
|
|
|
|
bareRepo5Path := filepath.Join(testReposDir, "repo5_pulls")
|
|
|
|
bareRepo5, err := OpenRepository(DefaultContext, bareRepo5Path)
|
|
|
|
if err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
defer bareRepo5.Close()
|
|
|
|
|
|
|
|
_, _ = bareRepo5.GetRefsBySha("8006ff9adbf0cb94da7dad9e537e53817f9fa5c0", "")
|
|
|
|
_, _ = bareRepo5.GetRefsBySha("d8e0bbb45f200e67d9a784ce55bd90821af45ebd", "")
|
|
|
|
_, _ = bareRepo5.GetRefsBySha("c83380d7056593c51a699d12b9c00627bd5743e9", "")
|
|
|
|
_, _ = bareRepo5.GetRefsBySha("58a4bcc53ac13e7ff76127e0fb518b5262bf09af", "")
|
|
|
|
}
|
2024-08-09 04:40:45 +02:00
|
|
|
|
|
|
|
func TestRepository_IsObjectExist(t *testing.T) {
|
|
|
|
repo, err := openRepositoryWithDefaultContext(filepath.Join(testReposDir, "repo1_bare"))
|
|
|
|
require.NoError(t, err)
|
|
|
|
defer repo.Close()
|
|
|
|
|
|
|
|
// FIXME: Inconsistent behavior between gogit and nogogit editions
|
|
|
|
// See the comment of IsObjectExist in gogit edition for more details.
|
|
|
|
supportShortHash := !isGogit
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
arg string
|
|
|
|
want bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "empty",
|
|
|
|
arg: "",
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "branch",
|
|
|
|
arg: "master",
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "commit hash",
|
|
|
|
arg: "ce064814f4a0d337b333e646ece456cd39fab612",
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "short commit hash",
|
|
|
|
arg: "ce06481",
|
|
|
|
want: supportShortHash,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "blob hash",
|
|
|
|
arg: "153f451b9ee7fa1da317ab17a127e9fd9d384310",
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "short blob hash",
|
|
|
|
arg: "153f451",
|
|
|
|
want: supportShortHash,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
assert.Equal(t, tt.want, repo.IsObjectExist(tt.arg))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRepository_IsReferenceExist(t *testing.T) {
|
|
|
|
repo, err := openRepositoryWithDefaultContext(filepath.Join(testReposDir, "repo1_bare"))
|
|
|
|
require.NoError(t, err)
|
|
|
|
defer repo.Close()
|
|
|
|
|
|
|
|
// FIXME: Inconsistent behavior between gogit and nogogit editions
|
|
|
|
// See the comment of IsReferenceExist in gogit edition for more details.
|
|
|
|
supportBlobHash := !isGogit
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
arg string
|
|
|
|
want bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "empty",
|
|
|
|
arg: "",
|
|
|
|
want: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "branch",
|
|
|
|
arg: "master",
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "commit hash",
|
|
|
|
arg: "ce064814f4a0d337b333e646ece456cd39fab612",
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "short commit hash",
|
|
|
|
arg: "ce06481",
|
|
|
|
want: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "blob hash",
|
|
|
|
arg: "153f451b9ee7fa1da317ab17a127e9fd9d384310",
|
|
|
|
want: supportBlobHash,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "short blob hash",
|
|
|
|
arg: "153f451",
|
|
|
|
want: supportBlobHash,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
assert.Equal(t, tt.want, repo.IsReferenceExist(tt.arg))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|