mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-07-07 09:55:41 +02:00
- Instead of invoking a new git command to check if a reference exists, use the already opened git repository that uses a batch check to check if the reference exists. - Instead of invoking a new git command to check if a branch exists, use the already opened git repository that uses a batch check to check if the branch exists. - Do not depend on `IsReferenceExist` as its no longer used by any other function. - Specify `--quiet` to not waste Git's time on printing something we do not use. - Run it via `Run` so no buffers are created for stdout and stderr. - Add a test that verifies `IsBranchExist` works and does not work for other types of references. Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/8425 Reviewed-by: Earl Warren <earl-warren@noreply.codeberg.org> Co-authored-by: Gusted <postmaster@gusted.xyz> Co-committed-by: Gusted <postmaster@gusted.xyz>
212 lines
5.4 KiB
Go
212 lines
5.4 KiB
Go
// Copyright 2018 The Gitea Authors. All rights reserved.
|
|
// Copyright 2025 The Forgejo Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package git
|
|
|
|
import (
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestRepository_GetBranches(t *testing.T) {
|
|
bareRepo1Path := filepath.Join(testReposDir, "repo1_bare")
|
|
bareRepo1, err := openRepositoryWithDefaultContext(bareRepo1Path)
|
|
require.NoError(t, err)
|
|
defer bareRepo1.Close()
|
|
|
|
branches, countAll, err := bareRepo1.GetBranchNames(0, 2)
|
|
|
|
require.NoError(t, err)
|
|
assert.Len(t, branches, 2)
|
|
assert.Equal(t, 3, countAll)
|
|
assert.ElementsMatch(t, []string{"master", "branch2"}, branches)
|
|
|
|
branches, countAll, err = bareRepo1.GetBranchNames(0, 0)
|
|
|
|
require.NoError(t, err)
|
|
assert.Len(t, branches, 3)
|
|
assert.Equal(t, 3, countAll)
|
|
assert.ElementsMatch(t, []string{"master", "branch2", "branch1"}, branches)
|
|
|
|
branches, countAll, err = bareRepo1.GetBranchNames(5, 1)
|
|
|
|
require.NoError(t, err)
|
|
assert.Empty(t, branches)
|
|
assert.Equal(t, 3, countAll)
|
|
assert.ElementsMatch(t, []string{}, branches)
|
|
}
|
|
|
|
func BenchmarkRepository_GetBranches(b *testing.B) {
|
|
bareRepo1Path := filepath.Join(testReposDir, "repo1_bare")
|
|
bareRepo1, err := openRepositoryWithDefaultContext(bareRepo1Path)
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
defer bareRepo1.Close()
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
_, _, err := bareRepo1.GetBranchNames(0, 0)
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
}
|
|
}
|
|
|
|
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", "")
|
|
require.NoError(t, err)
|
|
assert.Empty(t, branches)
|
|
|
|
// refs/pull/1/head
|
|
branches, err = bareRepo5.GetRefsBySha("c83380d7056593c51a699d12b9c00627bd5743e9", PullPrefix)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, []string{"refs/pull/1/head"}, branches)
|
|
|
|
branches, err = bareRepo5.GetRefsBySha("d8e0bbb45f200e67d9a784ce55bd90821af45ebd", BranchPrefix)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, []string{"refs/heads/master", "refs/heads/master-clone"}, branches)
|
|
|
|
branches, err = bareRepo5.GetRefsBySha("58a4bcc53ac13e7ff76127e0fb518b5262bf09af", BranchPrefix)
|
|
require.NoError(t, err)
|
|
assert.Equal(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", "")
|
|
}
|
|
|
|
func TestRepository_IsObjectExist(t *testing.T) {
|
|
repo, err := openRepositoryWithDefaultContext(filepath.Join(testReposDir, "repo1_bare"))
|
|
require.NoError(t, err)
|
|
defer repo.Close()
|
|
|
|
supportShortHash := true
|
|
|
|
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()
|
|
|
|
supportBlobHash := true
|
|
|
|
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))
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestIsBranchExist(t *testing.T) {
|
|
repo1Path := filepath.Join(testReposDir, "repo1_bare")
|
|
|
|
assert.True(t, IsBranchExist(t.Context(), repo1Path, "branch1"))
|
|
assert.True(t, IsBranchExist(t.Context(), repo1Path, "branch2"))
|
|
assert.True(t, IsBranchExist(t.Context(), repo1Path, "master"))
|
|
|
|
assert.False(t, IsBranchExist(t.Context(), repo1Path, "HEAD"))
|
|
assert.False(t, IsBranchExist(t.Context(), repo1Path, "153f451b9ee7fa1da317ab17a127e9fd9d384310"))
|
|
assert.False(t, IsBranchExist(t.Context(), repo1Path, "153f451b9ee7fa1da317ab17a127e9fd9d384310"))
|
|
assert.False(t, IsBranchExist(t.Context(), repo1Path, "signed-tag"))
|
|
assert.False(t, IsBranchExist(t.Context(), repo1Path, "test"))
|
|
}
|