* Include formatting check to the `make check` rule ... and give it its own standalone target too (make fmt-check) Show diff on fmt-check failure Do not allow running "fmt-check" with incompatible go version Also simplify the `fmt` rule * Forbid running "make fmt" with Go version != 1.7 or 1.8 * Ignore bindata.go for spelling and formatting checks also remove duplicated variable assignment for GOFILES * Run `make fmt`
		
			
				
	
	
		
			157 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			157 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2017 The Gitea Authors. All rights reserved.
 | |
| // Use of this source code is governed by a MIT-style
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| package models
 | |
| 
 | |
| import (
 | |
| 	"path"
 | |
| 	"testing"
 | |
| 
 | |
| 	"code.gitea.io/gitea/modules/markdown"
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| 
 | |
| 	"github.com/Unknwon/com"
 | |
| 	"github.com/stretchr/testify/assert"
 | |
| )
 | |
| 
 | |
| func TestRepo(t *testing.T) {
 | |
| 	repo := &Repository{Name: "testRepo"}
 | |
| 	repo.Owner = &User{Name: "testOwner"}
 | |
| 
 | |
| 	repo.Units = nil
 | |
| 	assert.Nil(t, repo.ComposeMetas())
 | |
| 
 | |
| 	externalTracker := RepoUnit{
 | |
| 		Type: UnitTypeExternalTracker,
 | |
| 		Config: &ExternalTrackerConfig{
 | |
| 			ExternalTrackerFormat: "https://someurl.com/{user}/{repo}/{issue}",
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	testSuccess := func(expectedStyle string) {
 | |
| 		repo.Units = []*RepoUnit{&externalTracker}
 | |
| 		repo.ExternalMetas = nil
 | |
| 		metas := repo.ComposeMetas()
 | |
| 		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(markdown.IssueNameStyleNumeric)
 | |
| 
 | |
| 	externalTracker.ExternalTrackerConfig().ExternalTrackerStyle = markdown.IssueNameStyleAlphanumeric
 | |
| 	testSuccess(markdown.IssueNameStyleAlphanumeric)
 | |
| 
 | |
| 	externalTracker.ExternalTrackerConfig().ExternalTrackerStyle = markdown.IssueNameStyleNumeric
 | |
| 	testSuccess(markdown.IssueNameStyleNumeric)
 | |
| }
 | |
| 
 | |
| func TestGetRepositoryCount(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	count, err1 := GetRepositoryCount(&User{ID: int64(10)})
 | |
| 	privateCount, err2 := GetPrivateRepositoryCount(&User{ID: int64(10)})
 | |
| 	publicCount, err3 := GetPublicRepositoryCount(&User{ID: int64(10)})
 | |
| 	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, PrepareTestDatabase())
 | |
| 
 | |
| 	count, err := GetPublicRepositoryCount(&User{ID: int64(10)})
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Equal(t, int64(1), count)
 | |
| }
 | |
| 
 | |
| func TestGetPrivateRepositoryCount(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	count, err := GetPrivateRepositoryCount(&User{ID: int64(10)})
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Equal(t, int64(2), count)
 | |
| }
 | |
| 
 | |
| func TestUpdateRepositoryVisibilityChanged(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	// Get sample repo and change visibility
 | |
| 	repo, err := GetRepositoryByID(9)
 | |
| 	repo.IsPrivate = true
 | |
| 
 | |
| 	// Update it
 | |
| 	err = UpdateRepository(repo, true)
 | |
| 	assert.NoError(t, err)
 | |
| 
 | |
| 	// Check visibility of action has become private
 | |
| 	act := Action{}
 | |
| 	_, err = x.ID(3).Get(&act)
 | |
| 
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Equal(t, true, act.IsPrivate)
 | |
| }
 | |
| 
 | |
| func TestGetUserFork(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	// User13 has repo 11 forked from repo10
 | |
| 	repo, err := GetRepositoryByID(10)
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.NotNil(t, repo)
 | |
| 	repo, err = repo.GetUserFork(13)
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.NotNil(t, repo)
 | |
| 
 | |
| 	repo, err = GetRepositoryByID(9)
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.NotNil(t, repo)
 | |
| 	repo, err = repo.GetUserFork(13)
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.Nil(t, repo)
 | |
| }
 | |
| 
 | |
| func TestForkRepository(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	// User13 has repo 11 forked from repo10
 | |
| 	repo, err := GetRepositoryByID(10)
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.NotNil(t, repo)
 | |
| 
 | |
| 	repo, err = ForkRepository(&User{ID: 13}, repo, "test", "test")
 | |
| 	assert.Nil(t, repo)
 | |
| 	assert.Error(t, err)
 | |
| 	assert.True(t, IsErrRepoAlreadyExist(err))
 | |
| }
 | |
| 
 | |
| func TestRepoAPIURL(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 	repo := AssertExistsAndLoadBean(t, &Repository{ID: 10}).(*Repository)
 | |
| 
 | |
| 	assert.Equal(t, "https://try.gitea.io/api/v1/repos/user12/repo10", repo.APIURL())
 | |
| }
 | |
| 
 | |
| func TestRepoLocalCopyPath(t *testing.T) {
 | |
| 	assert.NoError(t, PrepareTestDatabase())
 | |
| 
 | |
| 	repo, err := GetRepositoryByID(10)
 | |
| 	assert.NoError(t, err)
 | |
| 	assert.NotNil(t, repo)
 | |
| 
 | |
| 	// test default
 | |
| 	repoID := com.ToStr(repo.ID)
 | |
| 	expected := path.Join(setting.AppDataPath, setting.Repository.Local.LocalCopyPath, repoID)
 | |
| 	assert.Equal(t, expected, repo.LocalCopyPath())
 | |
| 
 | |
| 	// test absolute setting
 | |
| 	tempPath := "/tmp/gitea/local-copy-path"
 | |
| 	expected = path.Join(tempPath, repoID)
 | |
| 	setting.Repository.Local.LocalCopyPath = tempPath
 | |
| 	assert.Equal(t, expected, repo.LocalCopyPath())
 | |
| }
 |