2017-04-29 07:33:25 +03:00
// 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 integrations
import (
2017-10-10 04:23:29 +03:00
"fmt"
2017-04-29 07:33:25 +03:00
"net/http"
2019-03-15 17:19:09 +03:00
"net/url"
2021-09-22 08:38:34 +03:00
"os"
2017-04-29 07:33:25 +03:00
"testing"
2017-07-10 14:07:39 +03:00
"code.gitea.io/gitea/models"
2022-05-11 13:09:36 +03:00
"code.gitea.io/gitea/models/db"
access_model "code.gitea.io/gitea/models/perm/access"
2021-12-10 04:27:50 +03:00
repo_model "code.gitea.io/gitea/models/repo"
2021-11-16 11:53:21 +03:00
"code.gitea.io/gitea/models/unittest"
2021-11-24 12:49:20 +03:00
user_model "code.gitea.io/gitea/models/user"
2020-06-09 05:46:51 +03:00
"code.gitea.io/gitea/modules/setting"
2019-05-11 13:21:34 +03:00
api "code.gitea.io/gitea/modules/structs"
2020-08-11 23:05:34 +03:00
"code.gitea.io/gitea/modules/util"
2017-07-10 14:07:39 +03:00
"github.com/stretchr/testify/assert"
2017-04-29 07:33:25 +03:00
)
func TestAPIUserReposNotLogin ( t * testing . T ) {
2019-11-26 02:21:37 +03:00
defer prepareTestEnv ( t ) ( )
2021-11-24 12:49:20 +03:00
user := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 2 } ) . ( * user_model . User )
2017-07-10 14:07:39 +03:00
req := NewRequestf ( t , "GET" , "/api/v1/users/%s/repos" , user . Name )
resp := MakeRequest ( t , req , http . StatusOK )
2017-04-29 07:33:25 +03:00
2017-07-10 14:07:39 +03:00
var apiRepos [ ] api . Repository
DecodeJSON ( t , resp , & apiRepos )
2021-12-10 04:27:50 +03:00
expectedLen := unittest . GetCount ( t , repo_model . Repository { OwnerID : user . ID } ,
2021-11-16 11:53:21 +03:00
unittest . Cond ( "is_private = ?" , false ) )
2017-07-10 14:07:39 +03:00
assert . Len ( t , apiRepos , expectedLen )
for _ , repo := range apiRepos {
assert . EqualValues ( t , user . ID , repo . Owner . ID )
assert . False ( t , repo . Private )
}
}
2017-10-10 04:23:29 +03:00
func TestAPISearchRepo ( t * testing . T ) {
2019-11-26 02:21:37 +03:00
defer prepareTestEnv ( t ) ( )
2017-07-10 14:07:39 +03:00
const keyword = "test"
req := NewRequestf ( t , "GET" , "/api/v1/repos/search?q=%s" , keyword )
resp := MakeRequest ( t , req , http . StatusOK )
2017-04-30 08:08:09 +03:00
2017-09-20 12:24:38 +03:00
var body api . SearchResults
2017-07-10 14:07:39 +03:00
DecodeJSON ( t , resp , & body )
2017-09-20 12:24:38 +03:00
assert . NotEmpty ( t , body . Data )
for _ , repo := range body . Data {
assert . Contains ( t , repo . Name , keyword )
assert . False ( t , repo . Private )
2017-07-10 14:07:39 +03:00
}
2017-10-10 04:23:29 +03:00
2021-11-24 12:49:20 +03:00
user := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 15 } ) . ( * user_model . User )
user2 := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 16 } ) . ( * user_model . User )
user3 := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 18 } ) . ( * user_model . User )
user4 := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 20 } ) . ( * user_model . User )
orgUser := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 17 } ) . ( * user_model . User )
2017-10-10 04:23:29 +03:00
2020-06-09 05:46:51 +03:00
oldAPIDefaultNum := setting . API . DefaultPagingNum
defer func ( ) {
setting . API . DefaultPagingNum = oldAPIDefaultNum
} ( )
setting . API . DefaultPagingNum = 10
2017-10-10 04:23:29 +03:00
// Map of expected results, where key is user for login
2021-11-24 12:49:20 +03:00
type expectedResults map [ * user_model . User ] struct {
2017-10-10 04:23:29 +03:00
count int
repoOwnerID int64
repoName string
includesPrivate bool
}
testCases := [ ] struct {
name , requestURL string
expectedResults
} {
2022-01-20 20:46:10 +03:00
{
name : "RepositoriesMax50" , requestURL : "/api/v1/repos/search?limit=50&private=false" , expectedResults : expectedResults {
nil : { count : 30 } ,
user : { count : 30 } ,
user2 : { count : 30 } ,
} ,
2017-10-10 04:23:29 +03:00
} ,
2022-01-20 20:46:10 +03:00
{
name : "RepositoriesMax10" , requestURL : "/api/v1/repos/search?limit=10&private=false" , expectedResults : expectedResults {
nil : { count : 10 } ,
user : { count : 10 } ,
user2 : { count : 10 } ,
} ,
2017-10-10 04:23:29 +03:00
} ,
2022-01-20 20:46:10 +03:00
{
name : "RepositoriesDefault" , requestURL : "/api/v1/repos/search?default&private=false" , expectedResults : expectedResults {
nil : { count : 10 } ,
user : { count : 10 } ,
user2 : { count : 10 } ,
} ,
2017-10-10 04:23:29 +03:00
} ,
2022-01-20 20:46:10 +03:00
{
name : "RepositoriesByName" , requestURL : fmt . Sprintf ( "/api/v1/repos/search?q=%s&private=false" , "big_test_" ) , expectedResults : expectedResults {
nil : { count : 7 , repoName : "big_test_" } ,
user : { count : 7 , repoName : "big_test_" } ,
user2 : { count : 7 , repoName : "big_test_" } ,
} ,
2017-10-10 04:23:29 +03:00
} ,
2022-06-04 22:18:50 +03:00
{
name : "RepositoriesByName" , requestURL : fmt . Sprintf ( "/api/v1/repos/search?q=%s&private=false" , "user2/big_test_" ) , expectedResults : expectedResults {
user2 : { count : 2 , repoName : "big_test_" } ,
} ,
} ,
2022-01-20 20:46:10 +03:00
{
name : "RepositoriesAccessibleAndRelatedToUser" , requestURL : fmt . Sprintf ( "/api/v1/repos/search?uid=%d" , user . ID ) , expectedResults : expectedResults {
nil : { count : 5 } ,
user : { count : 9 , includesPrivate : true } ,
user2 : { count : 6 , includesPrivate : true } ,
} ,
2017-10-10 04:23:29 +03:00
} ,
2022-01-20 20:46:10 +03:00
{
name : "RepositoriesAccessibleAndRelatedToUser2" , requestURL : fmt . Sprintf ( "/api/v1/repos/search?uid=%d" , user2 . ID ) , expectedResults : expectedResults {
nil : { count : 1 } ,
user : { count : 2 , includesPrivate : true } ,
user2 : { count : 2 , includesPrivate : true } ,
user4 : { count : 1 } ,
} ,
2017-10-10 04:23:29 +03:00
} ,
2022-01-20 20:46:10 +03:00
{
name : "RepositoriesAccessibleAndRelatedToUser3" , requestURL : fmt . Sprintf ( "/api/v1/repos/search?uid=%d" , user3 . ID ) , expectedResults : expectedResults {
nil : { count : 1 } ,
user : { count : 4 , includesPrivate : true } ,
user2 : { count : 3 , includesPrivate : true } ,
user3 : { count : 4 , includesPrivate : true } ,
} ,
2017-10-17 18:20:22 +03:00
} ,
2022-01-20 20:46:10 +03:00
{
name : "RepositoriesOwnedByOrganization" , requestURL : fmt . Sprintf ( "/api/v1/repos/search?uid=%d" , orgUser . ID ) , expectedResults : expectedResults {
nil : { count : 1 , repoOwnerID : orgUser . ID } ,
user : { count : 2 , repoOwnerID : orgUser . ID , includesPrivate : true } ,
user2 : { count : 1 , repoOwnerID : orgUser . ID } ,
} ,
2017-10-10 04:23:29 +03:00
} ,
2017-10-27 00:16:13 +03:00
{ name : "RepositoriesAccessibleAndRelatedToUser4" , requestURL : fmt . Sprintf ( "/api/v1/repos/search?uid=%d" , user4 . ID ) , expectedResults : expectedResults {
nil : { count : 3 } ,
2019-05-15 18:24:39 +03:00
user : { count : 4 , includesPrivate : true } ,
2022-01-20 20:46:10 +03:00
user4 : { count : 7 , includesPrivate : true } ,
} } ,
2017-10-27 00:16:13 +03:00
{ name : "RepositoriesAccessibleAndRelatedToUser4/SearchModeSource" , requestURL : fmt . Sprintf ( "/api/v1/repos/search?uid=%d&mode=%s" , user4 . ID , "source" ) , expectedResults : expectedResults {
nil : { count : 0 } ,
2019-05-15 18:24:39 +03:00
user : { count : 1 , includesPrivate : true } ,
2022-01-20 20:46:10 +03:00
user4 : { count : 1 , includesPrivate : true } ,
} } ,
2017-10-27 00:16:13 +03:00
{ name : "RepositoriesAccessibleAndRelatedToUser4/SearchModeFork" , requestURL : fmt . Sprintf ( "/api/v1/repos/search?uid=%d&mode=%s" , user4 . ID , "fork" ) , expectedResults : expectedResults {
nil : { count : 1 } ,
user : { count : 1 } ,
2022-01-20 20:46:10 +03:00
user4 : { count : 2 , includesPrivate : true } ,
} } ,
2017-10-27 00:16:13 +03:00
{ name : "RepositoriesAccessibleAndRelatedToUser4/SearchModeFork/Exclusive" , requestURL : fmt . Sprintf ( "/api/v1/repos/search?uid=%d&mode=%s&exclusive=1" , user4 . ID , "fork" ) , expectedResults : expectedResults {
nil : { count : 1 } ,
user : { count : 1 } ,
2022-01-20 20:46:10 +03:00
user4 : { count : 2 , includesPrivate : true } ,
} } ,
2017-10-27 00:16:13 +03:00
{ name : "RepositoriesAccessibleAndRelatedToUser4/SearchModeMirror" , requestURL : fmt . Sprintf ( "/api/v1/repos/search?uid=%d&mode=%s" , user4 . ID , "mirror" ) , expectedResults : expectedResults {
nil : { count : 2 } ,
user : { count : 2 } ,
2022-01-20 20:46:10 +03:00
user4 : { count : 4 , includesPrivate : true } ,
} } ,
2017-10-27 00:16:13 +03:00
{ name : "RepositoriesAccessibleAndRelatedToUser4/SearchModeMirror/Exclusive" , requestURL : fmt . Sprintf ( "/api/v1/repos/search?uid=%d&mode=%s&exclusive=1" , user4 . ID , "mirror" ) , expectedResults : expectedResults {
nil : { count : 1 } ,
user : { count : 1 } ,
2022-01-20 20:46:10 +03:00
user4 : { count : 2 , includesPrivate : true } ,
} } ,
2017-10-27 00:16:13 +03:00
{ name : "RepositoriesAccessibleAndRelatedToUser4/SearchModeCollaborative" , requestURL : fmt . Sprintf ( "/api/v1/repos/search?uid=%d&mode=%s" , user4 . ID , "collaborative" ) , expectedResults : expectedResults {
nil : { count : 0 } ,
2019-05-15 18:24:39 +03:00
user : { count : 1 , includesPrivate : true } ,
2022-01-20 20:46:10 +03:00
user4 : { count : 1 , includesPrivate : true } ,
} } ,
2017-10-10 04:23:29 +03:00
}
for _ , testCase := range testCases {
t . Run ( testCase . name , func ( t * testing . T ) {
for userToLogin , expected := range testCase . expectedResults {
var session * TestSession
var testName string
2017-10-27 00:16:13 +03:00
var userID int64
2018-09-10 19:15:52 +03:00
var token string
2017-10-10 04:23:29 +03:00
if userToLogin != nil && userToLogin . ID > 0 {
testName = fmt . Sprintf ( "LoggedUser%d" , userToLogin . ID )
session = loginUser ( t , userToLogin . Name )
2018-09-10 19:15:52 +03:00
token = getTokenForLoggedInUser ( t , session )
2017-10-27 00:16:13 +03:00
userID = userToLogin . ID
2017-10-10 04:23:29 +03:00
} else {
testName = "AnonymousUser"
session = emptyTestSession ( t )
}
t . Run ( testName , func ( t * testing . T ) {
2018-09-10 19:15:52 +03:00
request := NewRequest ( t , "GET" , testCase . requestURL + "&token=" + token )
2017-10-10 04:23:29 +03:00
response := session . MakeRequest ( t , request , http . StatusOK )
var body api . SearchResults
DecodeJSON ( t , response , & body )
2019-05-15 18:24:39 +03:00
repoNames := make ( [ ] string , 0 , len ( body . Data ) )
for _ , repo := range body . Data {
repoNames = append ( repoNames , fmt . Sprintf ( "%d:%s:%t" , repo . ID , repo . FullName , repo . Private ) )
}
assert . Len ( t , repoNames , expected . count )
2017-10-10 04:23:29 +03:00
for _ , repo := range body . Data {
2017-10-27 00:16:13 +03:00
r := getRepo ( t , repo . ID )
2022-05-11 13:09:36 +03:00
hasAccess , err := access_model . HasAccess ( db . DefaultContext , userID , r )
2019-05-15 18:24:39 +03:00
assert . NoError ( t , err , "Error when checking if User: %d has access to %s: %v" , userID , repo . FullName , err )
assert . True ( t , hasAccess , "User: %d does not have access to %s" , userID , repo . FullName )
2017-10-27 00:16:13 +03:00
2017-10-10 04:23:29 +03:00
assert . NotEmpty ( t , repo . Name )
2019-05-15 18:24:39 +03:00
assert . Equal ( t , repo . Name , r . Name )
2017-10-10 04:23:29 +03:00
if len ( expected . repoName ) > 0 {
assert . Contains ( t , repo . Name , expected . repoName )
}
if expected . repoOwnerID > 0 {
assert . Equal ( t , expected . repoOwnerID , repo . Owner . ID )
}
if ! expected . includesPrivate {
2019-05-15 18:24:39 +03:00
assert . False ( t , repo . Private , "User: %d not expecting private repository: %s" , userID , repo . FullName )
2017-10-10 04:23:29 +03:00
}
}
} )
}
} )
}
2017-04-30 08:08:09 +03:00
}
2017-07-12 04:23:41 +03:00
2021-12-10 04:27:50 +03:00
var repoCache = make ( map [ int64 ] * repo_model . Repository )
2017-10-27 00:16:13 +03:00
2021-12-10 04:27:50 +03:00
func getRepo ( t * testing . T , repoID int64 ) * repo_model . Repository {
2017-10-27 00:16:13 +03:00
if _ , ok := repoCache [ repoID ] ; ! ok {
2021-12-10 04:27:50 +03:00
repoCache [ repoID ] = unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : repoID } ) . ( * repo_model . Repository )
2017-10-27 00:16:13 +03:00
}
return repoCache [ repoID ]
}
2017-07-12 04:23:41 +03:00
func TestAPIViewRepo ( t * testing . T ) {
2019-11-26 02:21:37 +03:00
defer prepareTestEnv ( t ) ( )
2017-07-12 04:23:41 +03:00
2020-04-06 21:42:30 +03:00
var repo api . Repository
2017-07-12 04:23:41 +03:00
req := NewRequest ( t , "GET" , "/api/v1/repos/user2/repo1" )
resp := MakeRequest ( t , req , http . StatusOK )
DecodeJSON ( t , resp , & repo )
assert . EqualValues ( t , 1 , repo . ID )
assert . EqualValues ( t , "repo1" , repo . Name )
2021-06-18 02:24:55 +03:00
assert . EqualValues ( t , 2 , repo . Releases )
2020-04-06 21:42:30 +03:00
assert . EqualValues ( t , 1 , repo . OpenIssues )
assert . EqualValues ( t , 3 , repo . OpenPulls )
req = NewRequest ( t , "GET" , "/api/v1/repos/user12/repo10" )
resp = MakeRequest ( t , req , http . StatusOK )
DecodeJSON ( t , resp , & repo )
assert . EqualValues ( t , 10 , repo . ID )
assert . EqualValues ( t , "repo10" , repo . Name )
assert . EqualValues ( t , 1 , repo . OpenPulls )
assert . EqualValues ( t , 1 , repo . Forks )
req = NewRequest ( t , "GET" , "/api/v1/repos/user5/repo4" )
resp = MakeRequest ( t , req , http . StatusOK )
DecodeJSON ( t , resp , & repo )
assert . EqualValues ( t , 4 , repo . ID )
assert . EqualValues ( t , "repo4" , repo . Name )
assert . EqualValues ( t , 1 , repo . Stars )
2017-07-12 04:23:41 +03:00
}
2017-07-13 14:14:15 +03:00
func TestAPIOrgRepos ( t * testing . T ) {
2019-11-26 02:21:37 +03:00
defer prepareTestEnv ( t ) ( )
2021-11-24 12:49:20 +03:00
user := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 2 } ) . ( * user_model . User )
user2 := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 1 } ) . ( * user_model . User )
user3 := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 5 } ) . ( * user_model . User )
2017-07-13 14:14:15 +03:00
// User3 is an Org. Check their repos.
2021-11-24 12:49:20 +03:00
sourceOrg := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 3 } ) . ( * user_model . User )
2017-07-13 14:14:15 +03:00
2021-11-24 12:49:20 +03:00
expectedResults := map [ * user_model . User ] struct {
2018-11-24 00:23:27 +03:00
count int
includesPrivate bool
} {
nil : { count : 1 } ,
2020-02-15 07:29:06 +03:00
user : { count : 3 , includesPrivate : true } ,
2018-11-24 00:23:27 +03:00
user2 : { count : 3 , includesPrivate : true } ,
user3 : { count : 1 } ,
}
for userToLogin , expected := range expectedResults {
var session * TestSession
var testName string
var token string
if userToLogin != nil && userToLogin . ID > 0 {
testName = fmt . Sprintf ( "LoggedUser%d" , userToLogin . ID )
session = loginUser ( t , userToLogin . Name )
token = getTokenForLoggedInUser ( t , session )
} else {
testName = "AnonymousUser"
session = emptyTestSession ( t )
}
t . Run ( testName , func ( t * testing . T ) {
req := NewRequestf ( t , "GET" , "/api/v1/orgs/%s/repos?token=" + token , sourceOrg . Name )
resp := session . MakeRequest ( t , req , http . StatusOK )
var apiRepos [ ] * api . Repository
DecodeJSON ( t , resp , & apiRepos )
assert . Len ( t , apiRepos , expected . count )
for _ , repo := range apiRepos {
if ! expected . includesPrivate {
assert . False ( t , repo . Private )
}
}
} )
2017-07-13 14:14:15 +03:00
}
}
2017-07-30 04:13:33 +03:00
func TestAPIGetRepoByIDUnauthorized ( t * testing . T ) {
2019-11-26 02:21:37 +03:00
defer prepareTestEnv ( t ) ( )
2021-11-24 12:49:20 +03:00
user := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 4 } ) . ( * user_model . User )
2018-09-10 19:15:52 +03:00
session := loginUser ( t , user . Name )
token := getTokenForLoggedInUser ( t , session )
req := NewRequestf ( t , "GET" , "/api/v1/repositories/2?token=" + token )
session . MakeRequest ( t , req , http . StatusNotFound )
2017-07-30 04:13:33 +03:00
}
2018-07-05 01:45:15 +03:00
func TestAPIRepoMigrate ( t * testing . T ) {
testCases := [ ] struct {
ctxUserID , userID int64
cloneURL , repoName string
expectedStatus int
} {
2020-07-24 07:46:38 +03:00
{ ctxUserID : 1 , userID : 2 , cloneURL : "https://github.com/go-gitea/test_repo.git" , repoName : "git-admin" , expectedStatus : http . StatusCreated } ,
{ ctxUserID : 2 , userID : 2 , cloneURL : "https://github.com/go-gitea/test_repo.git" , repoName : "git-own" , expectedStatus : http . StatusCreated } ,
{ ctxUserID : 2 , userID : 1 , cloneURL : "https://github.com/go-gitea/test_repo.git" , repoName : "git-bad" , expectedStatus : http . StatusForbidden } ,
{ ctxUserID : 2 , userID : 3 , cloneURL : "https://github.com/go-gitea/test_repo.git" , repoName : "git-org" , expectedStatus : http . StatusCreated } ,
{ ctxUserID : 2 , userID : 6 , cloneURL : "https://github.com/go-gitea/test_repo.git" , repoName : "git-bad-org" , expectedStatus : http . StatusForbidden } ,
2021-03-16 00:52:11 +03:00
{ ctxUserID : 2 , userID : 3 , cloneURL : "https://localhost:3000/user/test_repo.git" , repoName : "private-ip" , expectedStatus : http . StatusUnprocessableEntity } ,
2020-11-29 03:37:58 +03:00
{ ctxUserID : 2 , userID : 3 , cloneURL : "https://10.0.0.1/user/test_repo.git" , repoName : "private-ip" , expectedStatus : http . StatusUnprocessableEntity } ,
2018-07-05 01:45:15 +03:00
}
2019-11-26 02:21:37 +03:00
defer prepareTestEnv ( t ) ( )
2018-07-05 01:45:15 +03:00
for _ , testCase := range testCases {
2021-11-24 12:49:20 +03:00
user := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : testCase . ctxUserID } ) . ( * user_model . User )
2018-07-05 01:45:15 +03:00
session := loginUser ( t , user . Name )
2018-09-10 19:15:52 +03:00
token := getTokenForLoggedInUser ( t , session )
2020-09-11 01:29:19 +03:00
req := NewRequestWithJSON ( t , "POST" , "/api/v1/repos/migrate?token=" + token , & api . MigrateRepoOptions {
CloneAddr : testCase . cloneURL ,
RepoOwnerID : testCase . userID ,
RepoName : testCase . repoName ,
2018-07-05 01:45:15 +03:00
} )
2020-09-04 20:28:36 +03:00
resp := MakeRequest ( t , req , NoExpectedStatus )
if resp . Code == http . StatusUnprocessableEntity {
respJSON := map [ string ] string { }
DecodeJSON ( t , resp , & respJSON )
2020-11-29 03:37:58 +03:00
switch respJSON [ "message" ] {
case "Remote visit addressed rate limitation." :
2020-09-04 20:28:36 +03:00
t . Log ( "test hit github rate limitation" )
2021-11-20 12:34:05 +03:00
case "You can not import from disallowed hosts." :
2020-11-29 03:37:58 +03:00
assert . EqualValues ( t , "private-ip" , testCase . repoName )
default :
2021-11-22 09:18:31 +03:00
assert . Failf ( t , "unexpected error '%v' on url '%s'" , respJSON [ "message" ] , testCase . cloneURL )
2020-09-04 20:28:36 +03:00
}
} else {
assert . EqualValues ( t , testCase . expectedStatus , resp . Code )
}
2018-07-05 01:45:15 +03:00
}
}
2018-07-05 02:51:02 +03:00
2019-03-15 17:19:09 +03:00
func TestAPIRepoMigrateConflict ( t * testing . T ) {
onGiteaRun ( t , testAPIRepoMigrateConflict )
}
func testAPIRepoMigrateConflict ( t * testing . T , u * url . URL ) {
username := "user2"
baseAPITestContext := NewAPITestContext ( t , username , "repo1" )
u . Path = baseAPITestContext . GitPath ( )
t . Run ( "Existing" , func ( t * testing . T ) {
httpContext := baseAPITestContext
httpContext . Reponame = "repo-tmp-17"
2021-09-22 08:38:34 +03:00
dstPath , err := os . MkdirTemp ( "" , httpContext . Reponame )
2019-03-15 17:19:09 +03:00
assert . NoError ( t , err )
2020-08-11 23:05:34 +03:00
defer util . RemoveAll ( dstPath )
2019-03-15 17:19:09 +03:00
t . Run ( "CreateRepo" , doAPICreateRepository ( httpContext , false ) )
2022-05-20 17:08:52 +03:00
user , err := user_model . GetUserByName ( db . DefaultContext , httpContext . Username )
2019-03-15 17:19:09 +03:00
assert . NoError ( t , err )
userID := user . ID
2020-07-24 07:46:38 +03:00
cloneURL := "https://github.com/go-gitea/test_repo.git"
2019-03-15 17:19:09 +03:00
req := NewRequestWithJSON ( t , "POST" , "/api/v1/repos/migrate?token=" + httpContext . Token ,
2020-09-11 01:29:19 +03:00
& api . MigrateRepoOptions {
CloneAddr : cloneURL ,
RepoOwnerID : userID ,
RepoName : httpContext . Reponame ,
2019-03-15 17:19:09 +03:00
} )
resp := httpContext . Session . MakeRequest ( t , req , http . StatusConflict )
respJSON := map [ string ] string { }
DecodeJSON ( t , resp , & respJSON )
2019-11-09 01:21:00 +03:00
assert . Equal ( t , "The repository with the same name already exists." , respJSON [ "message" ] )
2019-03-15 17:19:09 +03:00
} )
}
2022-04-01 21:29:57 +03:00
// mirror-sync must fail with "400 (Bad Request)" when an attempt is made to
// sync a non-mirror repository.
func TestAPIMirrorSyncNonMirrorRepo ( t * testing . T ) {
defer prepareTestEnv ( t ) ( )
session := loginUser ( t , "user2" )
token := getTokenForLoggedInUser ( t , session )
var repo api . Repository
req := NewRequest ( t , "GET" , "/api/v1/repos/user2/repo1" )
resp := MakeRequest ( t , req , http . StatusOK )
DecodeJSON ( t , resp , & repo )
assert . EqualValues ( t , false , repo . Mirror )
req = NewRequestf ( t , "POST" , "/api/v1/repos/user2/repo1/mirror-sync?token=%s" , token )
resp = session . MakeRequest ( t , req , http . StatusBadRequest )
errRespJSON := map [ string ] string { }
DecodeJSON ( t , resp , & errRespJSON )
assert . Equal ( t , "Repository is not a mirror" , errRespJSON [ "message" ] )
}
2018-07-05 02:51:02 +03:00
func TestAPIOrgRepoCreate ( t * testing . T ) {
testCases := [ ] struct {
ctxUserID int64
orgName , repoName string
expectedStatus int
} {
{ ctxUserID : 1 , orgName : "user3" , repoName : "repo-admin" , expectedStatus : http . StatusCreated } ,
{ ctxUserID : 2 , orgName : "user3" , repoName : "repo-own" , expectedStatus : http . StatusCreated } ,
{ ctxUserID : 2 , orgName : "user6" , repoName : "repo-bad-org" , expectedStatus : http . StatusForbidden } ,
2019-11-20 14:27:49 +03:00
{ ctxUserID : 28 , orgName : "user3" , repoName : "repo-creator" , expectedStatus : http . StatusCreated } ,
{ ctxUserID : 28 , orgName : "user6" , repoName : "repo-not-creator" , expectedStatus : http . StatusForbidden } ,
2018-07-05 02:51:02 +03:00
}
2019-11-26 02:21:37 +03:00
defer prepareTestEnv ( t ) ( )
2018-07-05 02:51:02 +03:00
for _ , testCase := range testCases {
2021-11-24 12:49:20 +03:00
user := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : testCase . ctxUserID } ) . ( * user_model . User )
2018-07-05 02:51:02 +03:00
session := loginUser ( t , user . Name )
2018-09-10 19:15:52 +03:00
token := getTokenForLoggedInUser ( t , session )
req := NewRequestWithJSON ( t , "POST" , fmt . Sprintf ( "/api/v1/org/%s/repos?token=" + token , testCase . orgName ) , & api . CreateRepoOption {
2018-07-05 02:51:02 +03:00
Name : testCase . repoName ,
} )
session . MakeRequest ( t , req , testCase . expectedStatus )
}
}
2019-03-15 17:19:09 +03:00
func TestAPIRepoCreateConflict ( t * testing . T ) {
onGiteaRun ( t , testAPIRepoCreateConflict )
}
func testAPIRepoCreateConflict ( t * testing . T , u * url . URL ) {
username := "user2"
baseAPITestContext := NewAPITestContext ( t , username , "repo1" )
u . Path = baseAPITestContext . GitPath ( )
t . Run ( "Existing" , func ( t * testing . T ) {
httpContext := baseAPITestContext
httpContext . Reponame = "repo-tmp-17"
2021-09-22 08:38:34 +03:00
dstPath , err := os . MkdirTemp ( "" , httpContext . Reponame )
2019-03-15 17:19:09 +03:00
assert . NoError ( t , err )
2020-08-11 23:05:34 +03:00
defer util . RemoveAll ( dstPath )
2019-03-15 17:19:09 +03:00
t . Run ( "CreateRepo" , doAPICreateRepository ( httpContext , false ) )
req := NewRequestWithJSON ( t , "POST" , "/api/v1/user/repos?token=" + httpContext . Token ,
& api . CreateRepoOption {
Name : httpContext . Reponame ,
} )
resp := httpContext . Session . MakeRequest ( t , req , http . StatusConflict )
respJSON := map [ string ] string { }
DecodeJSON ( t , resp , & respJSON )
assert . Equal ( t , respJSON [ "message" ] , "The repository with the same name already exists." )
} )
}
2020-01-31 18:49:04 +03:00
func TestAPIRepoTransfer ( t * testing . T ) {
testCases := [ ] struct {
ctxUserID int64
newOwner string
teams * [ ] int64
expectedStatus int
} {
2021-03-01 03:47:30 +03:00
// Disclaimer for test story: "user1" is an admin, "user2" is normal user and part of in owner team of org "user3"
// Transfer to a user with teams in another org should fail
2020-01-31 18:49:04 +03:00
{ ctxUserID : 1 , newOwner : "user3" , teams : & [ ] int64 { 5 } , expectedStatus : http . StatusForbidden } ,
2021-03-01 03:47:30 +03:00
// Transfer to a user with non-existent team IDs should fail
{ ctxUserID : 1 , newOwner : "user2" , teams : & [ ] int64 { 2 } , expectedStatus : http . StatusUnprocessableEntity } ,
// Transfer should go through
2020-01-31 18:49:04 +03:00
{ ctxUserID : 1 , newOwner : "user3" , teams : & [ ] int64 { 2 } , expectedStatus : http . StatusAccepted } ,
2021-03-01 03:47:30 +03:00
// Let user transfer it back to himself
{ ctxUserID : 2 , newOwner : "user2" , expectedStatus : http . StatusAccepted } ,
// And revert transfer
{ ctxUserID : 2 , newOwner : "user3" , teams : & [ ] int64 { 2 } , expectedStatus : http . StatusAccepted } ,
// Cannot start transfer to an existing repo
{ ctxUserID : 2 , newOwner : "user3" , teams : nil , expectedStatus : http . StatusUnprocessableEntity } ,
// Start transfer, repo is now in pending transfer mode
{ ctxUserID : 2 , newOwner : "user6" , teams : nil , expectedStatus : http . StatusCreated } ,
2020-01-31 18:49:04 +03:00
}
defer prepareTestEnv ( t ) ( )
2022-01-20 20:46:10 +03:00
// create repo to move
2021-11-24 12:49:20 +03:00
user := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 1 } ) . ( * user_model . User )
2020-01-31 18:49:04 +03:00
session := loginUser ( t , user . Name )
token := getTokenForLoggedInUser ( t , session )
repoName := "moveME"
2021-06-18 17:46:22 +03:00
apiRepo := new ( api . Repository )
2020-01-31 18:49:04 +03:00
req := NewRequestWithJSON ( t , "POST" , fmt . Sprintf ( "/api/v1/user/repos?token=%s" , token ) , & api . CreateRepoOption {
Name : repoName ,
Description : "repo move around" ,
Private : false ,
Readme : "Default" ,
AutoInit : true ,
} )
resp := session . MakeRequest ( t , req , http . StatusCreated )
2021-06-18 17:46:22 +03:00
DecodeJSON ( t , resp , apiRepo )
2020-01-31 18:49:04 +03:00
2022-01-20 20:46:10 +03:00
// start testing
2020-01-31 18:49:04 +03:00
for _ , testCase := range testCases {
2021-11-24 12:49:20 +03:00
user = unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : testCase . ctxUserID } ) . ( * user_model . User )
2021-12-10 04:27:50 +03:00
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : apiRepo . ID } ) . ( * repo_model . Repository )
2020-01-31 18:49:04 +03:00
session = loginUser ( t , user . Name )
token = getTokenForLoggedInUser ( t , session )
req = NewRequestWithJSON ( t , "POST" , fmt . Sprintf ( "/api/v1/repos/%s/%s/transfer?token=%s" , repo . OwnerName , repo . Name , token ) , & api . TransferRepoOption {
NewOwner : testCase . newOwner ,
TeamIDs : testCase . teams ,
} )
session . MakeRequest ( t , req , testCase . expectedStatus )
}
2022-01-20 20:46:10 +03:00
// cleanup
2021-12-10 04:27:50 +03:00
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : apiRepo . ID } ) . ( * repo_model . Repository )
2020-01-31 18:49:04 +03:00
_ = models . DeleteRepository ( user , repo . OwnerID , repo . ID )
}
2021-06-17 17:02:34 +03:00
2021-12-24 07:26:52 +03:00
func transfer ( t * testing . T ) * repo_model . Repository {
2022-01-20 20:46:10 +03:00
// create repo to move
2021-12-24 07:26:52 +03:00
user := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 2 } ) . ( * user_model . User )
session := loginUser ( t , user . Name )
token := getTokenForLoggedInUser ( t , session )
repoName := "moveME"
apiRepo := new ( api . Repository )
req := NewRequestWithJSON ( t , "POST" , fmt . Sprintf ( "/api/v1/user/repos?token=%s" , token ) , & api . CreateRepoOption {
Name : repoName ,
Description : "repo move around" ,
Private : false ,
Readme : "Default" ,
AutoInit : true ,
} )
resp := session . MakeRequest ( t , req , http . StatusCreated )
DecodeJSON ( t , resp , apiRepo )
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : apiRepo . ID } ) . ( * repo_model . Repository )
req = NewRequestWithJSON ( t , "POST" , fmt . Sprintf ( "/api/v1/repos/%s/%s/transfer?token=%s" , repo . OwnerName , repo . Name , token ) , & api . TransferRepoOption {
NewOwner : "user4" ,
} )
session . MakeRequest ( t , req , http . StatusCreated )
return repo
}
func TestAPIAcceptTransfer ( t * testing . T ) {
defer prepareTestEnv ( t ) ( )
repo := transfer ( t )
// try to accept with not authorized user
session := loginUser ( t , "user2" )
token := getTokenForLoggedInUser ( t , session )
req := NewRequest ( t , "POST" , fmt . Sprintf ( "/api/v1/repos/%s/%s/transfer/reject?token=%s" , repo . OwnerName , repo . Name , token ) )
session . MakeRequest ( t , req , http . StatusForbidden )
// try to accept repo that's not marked as transferred
req = NewRequest ( t , "POST" , fmt . Sprintf ( "/api/v1/repos/%s/%s/transfer/accept?token=%s" , "user2" , "repo1" , token ) )
session . MakeRequest ( t , req , http . StatusNotFound )
// accept transfer
session = loginUser ( t , "user4" )
token = getTokenForLoggedInUser ( t , session )
req = NewRequest ( t , "POST" , fmt . Sprintf ( "/api/v1/repos/%s/%s/transfer/accept?token=%s" , repo . OwnerName , repo . Name , token ) )
resp := session . MakeRequest ( t , req , http . StatusAccepted )
apiRepo := new ( api . Repository )
DecodeJSON ( t , resp , apiRepo )
assert . Equal ( t , "user4" , apiRepo . Owner . UserName )
}
func TestAPIRejectTransfer ( t * testing . T ) {
defer prepareTestEnv ( t ) ( )
repo := transfer ( t )
// try to reject with not authorized user
session := loginUser ( t , "user2" )
token := getTokenForLoggedInUser ( t , session )
req := NewRequest ( t , "POST" , fmt . Sprintf ( "/api/v1/repos/%s/%s/transfer/reject?token=%s" , repo . OwnerName , repo . Name , token ) )
session . MakeRequest ( t , req , http . StatusForbidden )
// try to reject repo that's not marked as transferred
req = NewRequest ( t , "POST" , fmt . Sprintf ( "/api/v1/repos/%s/%s/transfer/reject?token=%s" , "user2" , "repo1" , token ) )
session . MakeRequest ( t , req , http . StatusNotFound )
// reject transfer
session = loginUser ( t , "user4" )
token = getTokenForLoggedInUser ( t , session )
req = NewRequest ( t , "POST" , fmt . Sprintf ( "/api/v1/repos/%s/%s/transfer/reject?token=%s" , repo . OwnerName , repo . Name , token ) )
resp := session . MakeRequest ( t , req , http . StatusOK )
apiRepo := new ( api . Repository )
DecodeJSON ( t , resp , apiRepo )
assert . Equal ( t , "user2" , apiRepo . Owner . UserName )
}
2021-07-05 18:29:08 +03:00
func TestAPIGenerateRepo ( t * testing . T ) {
defer prepareTestEnv ( t ) ( )
2021-11-24 12:49:20 +03:00
user := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 1 } ) . ( * user_model . User )
2021-07-05 18:29:08 +03:00
session := loginUser ( t , user . Name )
token := getTokenForLoggedInUser ( t , session )
2021-12-10 04:27:50 +03:00
templateRepo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : 44 } ) . ( * repo_model . Repository )
2021-07-05 18:29:08 +03:00
// user
repo := new ( api . Repository )
req := NewRequestWithJSON ( t , "POST" , fmt . Sprintf ( "/api/v1/repos/%s/%s/generate?token=%s" , templateRepo . OwnerName , templateRepo . Name , token ) , & api . GenerateRepoOption {
Owner : user . Name ,
Name : "new-repo" ,
Description : "test generate repo" ,
Private : false ,
GitContent : true ,
} )
resp := session . MakeRequest ( t , req , http . StatusCreated )
DecodeJSON ( t , resp , repo )
assert . Equal ( t , "new-repo" , repo . Name )
// org
req = NewRequestWithJSON ( t , "POST" , fmt . Sprintf ( "/api/v1/repos/%s/%s/generate?token=%s" , templateRepo . OwnerName , templateRepo . Name , token ) , & api . GenerateRepoOption {
Owner : "user3" ,
Name : "new-repo" ,
Description : "test generate repo" ,
Private : false ,
GitContent : true ,
} )
resp = session . MakeRequest ( t , req , http . StatusCreated )
DecodeJSON ( t , resp , repo )
assert . Equal ( t , "new-repo" , repo . Name )
}
2021-06-17 17:02:34 +03:00
func TestAPIRepoGetReviewers ( t * testing . T ) {
defer prepareTestEnv ( t ) ( )
2021-11-24 12:49:20 +03:00
user := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 2 } ) . ( * user_model . User )
2021-06-17 17:02:34 +03:00
session := loginUser ( t , user . Name )
token := getTokenForLoggedInUser ( t , session )
2021-12-10 04:27:50 +03:00
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : 1 } ) . ( * repo_model . Repository )
2021-06-17 17:02:34 +03:00
req := NewRequestf ( t , "GET" , "/api/v1/repos/%s/%s/reviewers?token=%s" , user . Name , repo . Name , token )
resp := session . MakeRequest ( t , req , http . StatusOK )
var reviewers [ ] * api . User
DecodeJSON ( t , resp , & reviewers )
assert . Len ( t , reviewers , 4 )
}
func TestAPIRepoGetAssignees ( t * testing . T ) {
defer prepareTestEnv ( t ) ( )
2021-11-24 12:49:20 +03:00
user := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : 2 } ) . ( * user_model . User )
2021-06-17 17:02:34 +03:00
session := loginUser ( t , user . Name )
token := getTokenForLoggedInUser ( t , session )
2021-12-10 04:27:50 +03:00
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : 1 } ) . ( * repo_model . Repository )
2021-06-17 17:02:34 +03:00
req := NewRequestf ( t , "GET" , "/api/v1/repos/%s/%s/assignees?token=%s" , user . Name , repo . Name , token )
resp := session . MakeRequest ( t , req , http . StatusOK )
var assignees [ ] * api . User
DecodeJSON ( t , resp , & assignees )
assert . Len ( t , assignees , 1 )
}