| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238 |
- // Copyright 2017 The Gitea Authors. All rights reserved.
- // SPDX-License-Identifier: MIT
-
- package repo
-
- import (
- "testing"
-
- "code.gitea.io/gitea/models/unit"
- "code.gitea.io/gitea/models/unittest"
- user_model "code.gitea.io/gitea/models/user"
- "code.gitea.io/gitea/modules/markup"
- "code.gitea.io/gitea/modules/optional"
- "code.gitea.io/gitea/modules/setting"
- "code.gitea.io/gitea/modules/test"
-
- "github.com/stretchr/testify/assert"
- "github.com/stretchr/testify/require"
- )
-
- var (
- countRepospts = CountRepositoryOptions{OwnerID: 10}
- countReposptsPublic = CountRepositoryOptions{OwnerID: 10, Private: optional.Some(false)}
- countReposptsPrivate = CountRepositoryOptions{OwnerID: 10, Private: optional.Some(true)}
- )
-
- func TestGetRepositoryCount(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
-
- ctx := t.Context()
- count, err1 := CountRepositories(ctx, countRepospts)
- privateCount, err2 := CountRepositories(ctx, countReposptsPrivate)
- publicCount, err3 := CountRepositories(ctx, countReposptsPublic)
- assert.NoError(t, err1)
- assert.NoError(t, err2)
- assert.NoError(t, err3)
- assert.Equal(t, int64(3), count)
- assert.Equal(t, privateCount+publicCount, count)
- }
-
- func TestGetPublicRepositoryCount(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
-
- count, err := CountRepositories(t.Context(), countReposptsPublic)
- assert.NoError(t, err)
- assert.Equal(t, int64(1), count)
- }
-
- func TestGetPrivateRepositoryCount(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
-
- count, err := CountRepositories(t.Context(), countReposptsPrivate)
- assert.NoError(t, err)
- assert.Equal(t, int64(2), count)
- }
-
- func TestRepoAPIURL(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
- repo := unittest.AssertExistsAndLoadBean(t, &Repository{ID: 10})
-
- assert.Equal(t, "https://try.gitea.io/api/v1/repos/user12/repo10", repo.APIURL())
- }
-
- func TestWatchRepo(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
-
- repo := unittest.AssertExistsAndLoadBean(t, &Repository{ID: 3})
- user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
-
- assert.NoError(t, WatchRepo(t.Context(), user, repo, true))
- unittest.AssertExistsAndLoadBean(t, &Watch{RepoID: repo.ID, UserID: user.ID})
- unittest.CheckConsistencyFor(t, &Repository{ID: repo.ID})
-
- assert.NoError(t, WatchRepo(t.Context(), user, repo, false))
- unittest.AssertNotExistsBean(t, &Watch{RepoID: repo.ID, UserID: user.ID})
- unittest.CheckConsistencyFor(t, &Repository{ID: repo.ID})
- }
-
- func TestMetas(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
-
- repo := &Repository{Name: "testRepo"}
- repo.Owner = &user_model.User{Name: "testOwner"}
- repo.OwnerName = repo.Owner.Name
-
- repo.Units = nil
-
- metas := repo.ComposeCommentMetas(t.Context())
- assert.Equal(t, "testRepo", metas["repo"])
- assert.Equal(t, "testOwner", metas["user"])
-
- externalTracker := RepoUnit{
- Type: unit.TypeExternalTracker,
- Config: &ExternalTrackerConfig{
- ExternalTrackerFormat: "https://someurl.com/{user}/{repo}/{issue}",
- },
- }
-
- testSuccess := func(expectedStyle string) {
- repo.Units = []*RepoUnit{&externalTracker}
- repo.commonRenderingMetas = nil
- metas := repo.ComposeCommentMetas(t.Context())
- assert.Equal(t, expectedStyle, metas["style"])
- assert.Equal(t, "testRepo", metas["repo"])
- assert.Equal(t, "testOwner", metas["user"])
- assert.Equal(t, "https://someurl.com/{user}/{repo}/{issue}", metas["format"])
- }
-
- testSuccess(markup.IssueNameStyleNumeric)
-
- externalTracker.ExternalTrackerConfig().ExternalTrackerStyle = markup.IssueNameStyleAlphanumeric
- testSuccess(markup.IssueNameStyleAlphanumeric)
-
- externalTracker.ExternalTrackerConfig().ExternalTrackerStyle = markup.IssueNameStyleNumeric
- testSuccess(markup.IssueNameStyleNumeric)
-
- externalTracker.ExternalTrackerConfig().ExternalTrackerStyle = markup.IssueNameStyleRegexp
- testSuccess(markup.IssueNameStyleRegexp)
-
- repo, err := GetRepositoryByID(t.Context(), 3)
- assert.NoError(t, err)
-
- metas = repo.ComposeCommentMetas(t.Context())
- assert.Contains(t, metas, "org")
- assert.Contains(t, metas, "teams")
- assert.Equal(t, "org3", metas["org"])
- assert.Equal(t, ",owners,team1,", metas["teams"])
- }
-
- func TestGetRepositoryByURL(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
-
- t.Run("InvalidPath", func(t *testing.T) {
- repo, err := GetRepositoryByURL(t.Context(), "something")
- assert.Nil(t, repo)
- assert.Error(t, err)
- })
-
- testRepo2 := func(t *testing.T, url string) {
- repo, err := GetRepositoryByURL(t.Context(), url)
- require.NoError(t, err)
- assert.EqualValues(t, 2, repo.ID)
- assert.EqualValues(t, 2, repo.OwnerID)
- }
-
- t.Run("ValidHttpURL", func(t *testing.T) {
- testRepo2(t, "https://try.gitea.io/user2/repo2")
- testRepo2(t, "https://try.gitea.io/user2/repo2.git")
- })
-
- t.Run("ValidGitSshURL", func(t *testing.T) {
- testRepo2(t, "git+ssh://sshuser@try.gitea.io/user2/repo2")
- testRepo2(t, "git+ssh://sshuser@try.gitea.io/user2/repo2.git")
-
- testRepo2(t, "git+ssh://try.gitea.io/user2/repo2")
- testRepo2(t, "git+ssh://try.gitea.io/user2/repo2.git")
- })
-
- t.Run("ValidImplicitSshURL", func(t *testing.T) {
- testRepo2(t, "sshuser@try.gitea.io:user2/repo2")
- testRepo2(t, "sshuser@try.gitea.io:user2/repo2.git")
-
- testRelax := func(t *testing.T, url string) {
- repo, err := GetRepositoryByURLRelax(t.Context(), url)
- require.NoError(t, err)
- assert.Equal(t, int64(2), repo.ID)
- assert.Equal(t, int64(2), repo.OwnerID)
- }
- // TODO: it doesn't seem to be common git ssh URL, should we really support this?
- testRelax(t, "try.gitea.io:user2/repo2")
- testRelax(t, "try.gitea.io:user2/repo2.git")
- })
- }
-
- func TestComposeSSHCloneURL(t *testing.T) {
- defer test.MockVariableValue(&setting.SSH, setting.SSH)()
- defer test.MockVariableValue(&setting.Repository, setting.Repository)()
-
- setting.SSH.User = "git"
-
- // test SSH_DOMAIN
- setting.SSH.Domain = "domain"
- setting.SSH.Port = 22
- setting.Repository.UseCompatSSHURI = false
- assert.Equal(t, "git@domain:user/repo.git", ComposeSSHCloneURL(&user_model.User{Name: "doer"}, "user", "repo"))
- setting.Repository.UseCompatSSHURI = true
- assert.Equal(t, "ssh://git@domain/user/repo.git", ComposeSSHCloneURL(&user_model.User{Name: "doer"}, "user", "repo"))
- // test SSH_DOMAIN while use non-standard SSH port
- setting.SSH.Port = 123
- setting.Repository.UseCompatSSHURI = false
- assert.Equal(t, "ssh://git@domain:123/user/repo.git", ComposeSSHCloneURL(nil, "user", "repo"))
- setting.Repository.UseCompatSSHURI = true
- assert.Equal(t, "ssh://git@domain:123/user/repo.git", ComposeSSHCloneURL(nil, "user", "repo"))
-
- // test IPv6 SSH_DOMAIN
- setting.Repository.UseCompatSSHURI = false
- setting.SSH.Domain = "::1"
- setting.SSH.Port = 22
- assert.Equal(t, "git@[::1]:user/repo.git", ComposeSSHCloneURL(nil, "user", "repo"))
- setting.SSH.Port = 123
- assert.Equal(t, "ssh://git@[::1]:123/user/repo.git", ComposeSSHCloneURL(nil, "user", "repo"))
-
- setting.SSH.User = "(DOER_USERNAME)"
- setting.SSH.Domain = "domain"
- setting.SSH.Port = 22
- assert.Equal(t, "doer@domain:user/repo.git", ComposeSSHCloneURL(&user_model.User{Name: "doer"}, "user", "repo"))
- setting.SSH.Port = 123
- assert.Equal(t, "ssh://doer@domain:123/user/repo.git", ComposeSSHCloneURL(&user_model.User{Name: "doer"}, "user", "repo"))
- }
-
- func TestIsUsableRepoName(t *testing.T) {
- assert.NoError(t, IsUsableRepoName("a"))
- assert.NoError(t, IsUsableRepoName("-1_."))
- assert.NoError(t, IsUsableRepoName(".profile"))
-
- assert.Error(t, IsUsableRepoName("-"))
- assert.Error(t, IsUsableRepoName("🌞"))
- assert.Error(t, IsUsableRepoName("the/repo"))
- assert.Error(t, IsUsableRepoName("the..repo"))
- assert.Error(t, IsUsableRepoName("foo.wiki"))
- assert.Error(t, IsUsableRepoName("foo.git"))
- assert.Error(t, IsUsableRepoName("foo.RSS"))
- }
-
- func TestIsValidSSHAccessRepoName(t *testing.T) {
- assert.True(t, IsValidSSHAccessRepoName("a"))
- assert.True(t, IsValidSSHAccessRepoName("-1_."))
- assert.True(t, IsValidSSHAccessRepoName(".profile"))
- assert.True(t, IsValidSSHAccessRepoName("foo.wiki"))
-
- assert.False(t, IsValidSSHAccessRepoName("-"))
- assert.False(t, IsValidSSHAccessRepoName("🌞"))
- assert.False(t, IsValidSSHAccessRepoName("the/repo"))
- assert.False(t, IsValidSSHAccessRepoName("the..repo"))
- assert.False(t, IsValidSSHAccessRepoName("foo.git"))
- assert.False(t, IsValidSSHAccessRepoName("foo.RSS"))
- }
|