2019-04-17 08:31:08 +03:00
// Copyright 2019 The Gitea Authors. All rights reserved.
2022-11-27 13:20:29 -05:00
// SPDX-License-Identifier: MIT
2019-04-17 08:31:08 +03:00
2022-09-02 15:18:23 -04:00
package integration
2019-04-17 08:31:08 +03:00
import (
"fmt"
"net/http"
"testing"
2023-01-17 16:46:03 -05:00
auth_model "code.gitea.io/gitea/models/auth"
2021-12-10 09:27:50 +08:00
repo_model "code.gitea.io/gitea/models/repo"
2021-11-16 16:53:21 +08:00
"code.gitea.io/gitea/models/unittest"
2021-11-24 17:49:20 +08:00
user_model "code.gitea.io/gitea/models/user"
2019-05-11 18:21:34 +08:00
api "code.gitea.io/gitea/modules/structs"
2022-09-02 15:18:23 -04:00
"code.gitea.io/gitea/tests"
2019-04-17 08:31:08 +03:00
"github.com/stretchr/testify/assert"
)
const testHookContent = ` # ! / bin / bash
echo Hello , World !
`
func TestAPIListGitHooks ( t * testing . T ) {
2022-09-02 15:18:23 -04:00
defer tests . PrepareTestEnv ( t ) ( )
2019-04-17 08:31:08 +03:00
2022-08-16 10:22:25 +08:00
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : 37 } )
owner := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : repo . OwnerID } )
2019-04-17 08:31:08 +03:00
// user1 is an admin user
session := loginUser ( t , "user1" )
2023-01-17 16:46:03 -05:00
token := getTokenForLoggedInUser ( t , session , auth_model . AccessTokenScopeReadRepoHook )
2019-04-17 08:31:08 +03:00
req := NewRequestf ( t , "GET" , "/api/v1/repos/%s/%s/hooks/git?token=%s" ,
owner . Name , repo . Name , token )
resp := MakeRequest ( t , req , http . StatusOK )
var apiGitHooks [ ] * api . GitHook
DecodeJSON ( t , resp , & apiGitHooks )
assert . Len ( t , apiGitHooks , 3 )
for _ , apiGitHook := range apiGitHooks {
if apiGitHook . Name == "pre-receive" {
assert . True ( t , apiGitHook . IsActive )
assert . Equal ( t , testHookContent , apiGitHook . Content )
} else {
assert . False ( t , apiGitHook . IsActive )
assert . Empty ( t , apiGitHook . Content )
}
}
}
func TestAPIListGitHooksNoHooks ( t * testing . T ) {
2022-09-02 15:18:23 -04:00
defer tests . PrepareTestEnv ( t ) ( )
2019-04-17 08:31:08 +03:00
2022-08-16 10:22:25 +08:00
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : 1 } )
owner := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : repo . OwnerID } )
2019-04-17 08:31:08 +03:00
// user1 is an admin user
session := loginUser ( t , "user1" )
2023-01-17 16:46:03 -05:00
token := getTokenForLoggedInUser ( t , session , auth_model . AccessTokenScopeReadRepoHook )
2019-04-17 08:31:08 +03:00
req := NewRequestf ( t , "GET" , "/api/v1/repos/%s/%s/hooks/git?token=%s" ,
owner . Name , repo . Name , token )
resp := MakeRequest ( t , req , http . StatusOK )
var apiGitHooks [ ] * api . GitHook
DecodeJSON ( t , resp , & apiGitHooks )
assert . Len ( t , apiGitHooks , 3 )
for _ , apiGitHook := range apiGitHooks {
assert . False ( t , apiGitHook . IsActive )
assert . Empty ( t , apiGitHook . Content )
}
}
func TestAPIListGitHooksNoAccess ( t * testing . T ) {
2022-09-02 15:18:23 -04:00
defer tests . PrepareTestEnv ( t ) ( )
2019-04-17 08:31:08 +03:00
2022-08-16 10:22:25 +08:00
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : 1 } )
owner := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : repo . OwnerID } )
2019-04-17 08:31:08 +03:00
session := loginUser ( t , owner . Name )
2023-01-17 16:46:03 -05:00
token := getTokenForLoggedInUser ( t , session , auth_model . AccessTokenScopeReadRepoHook )
2019-04-17 08:31:08 +03:00
req := NewRequestf ( t , "GET" , "/api/v1/repos/%s/%s/hooks/git?token=%s" ,
owner . Name , repo . Name , token )
MakeRequest ( t , req , http . StatusForbidden )
}
func TestAPIGetGitHook ( t * testing . T ) {
2022-09-02 15:18:23 -04:00
defer tests . PrepareTestEnv ( t ) ( )
2019-04-17 08:31:08 +03:00
2022-08-16 10:22:25 +08:00
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : 37 } )
owner := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : repo . OwnerID } )
2019-04-17 08:31:08 +03:00
// user1 is an admin user
session := loginUser ( t , "user1" )
2023-01-17 16:46:03 -05:00
token := getTokenForLoggedInUser ( t , session , auth_model . AccessTokenScopeReadRepoHook )
2019-04-17 08:31:08 +03:00
req := NewRequestf ( t , "GET" , "/api/v1/repos/%s/%s/hooks/git/pre-receive?token=%s" ,
owner . Name , repo . Name , token )
resp := MakeRequest ( t , req , http . StatusOK )
var apiGitHook * api . GitHook
DecodeJSON ( t , resp , & apiGitHook )
assert . True ( t , apiGitHook . IsActive )
assert . Equal ( t , testHookContent , apiGitHook . Content )
}
func TestAPIGetGitHookNoAccess ( t * testing . T ) {
2022-09-02 15:18:23 -04:00
defer tests . PrepareTestEnv ( t ) ( )
2019-04-17 08:31:08 +03:00
2022-08-16 10:22:25 +08:00
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : 1 } )
owner := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : repo . OwnerID } )
2019-04-17 08:31:08 +03:00
session := loginUser ( t , owner . Name )
2023-01-17 16:46:03 -05:00
token := getTokenForLoggedInUser ( t , session , auth_model . AccessTokenScopeReadRepoHook )
2019-04-17 08:31:08 +03:00
req := NewRequestf ( t , "GET" , "/api/v1/repos/%s/%s/hooks/git/pre-receive?token=%s" ,
owner . Name , repo . Name , token )
MakeRequest ( t , req , http . StatusForbidden )
}
func TestAPIEditGitHook ( t * testing . T ) {
2022-09-02 15:18:23 -04:00
defer tests . PrepareTestEnv ( t ) ( )
2019-04-17 08:31:08 +03:00
2022-08-16 10:22:25 +08:00
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : 1 } )
owner := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : repo . OwnerID } )
2019-04-17 08:31:08 +03:00
// user1 is an admin user
session := loginUser ( t , "user1" )
2023-01-17 16:46:03 -05:00
token := getTokenForLoggedInUser ( t , session , auth_model . AccessTokenScopeAdminRepoHook )
2019-04-17 08:31:08 +03:00
urlStr := fmt . Sprintf ( "/api/v1/repos/%s/%s/hooks/git/pre-receive?token=%s" ,
owner . Name , repo . Name , token )
req := NewRequestWithJSON ( t , "PATCH" , urlStr , & api . EditGitHookOption {
Content : testHookContent ,
} )
resp := MakeRequest ( t , req , http . StatusOK )
var apiGitHook * api . GitHook
DecodeJSON ( t , resp , & apiGitHook )
assert . True ( t , apiGitHook . IsActive )
assert . Equal ( t , testHookContent , apiGitHook . Content )
req = NewRequestf ( t , "GET" , "/api/v1/repos/%s/%s/hooks/git/pre-receive?token=%s" ,
owner . Name , repo . Name , token )
resp = MakeRequest ( t , req , http . StatusOK )
var apiGitHook2 * api . GitHook
DecodeJSON ( t , resp , & apiGitHook2 )
assert . True ( t , apiGitHook2 . IsActive )
assert . Equal ( t , testHookContent , apiGitHook2 . Content )
}
func TestAPIEditGitHookNoAccess ( t * testing . T ) {
2022-09-02 15:18:23 -04:00
defer tests . PrepareTestEnv ( t ) ( )
2019-04-17 08:31:08 +03:00
2022-08-16 10:22:25 +08:00
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : 1 } )
owner := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : repo . OwnerID } )
2019-04-17 08:31:08 +03:00
session := loginUser ( t , owner . Name )
2023-01-17 16:46:03 -05:00
token := getTokenForLoggedInUser ( t , session , auth_model . AccessTokenScopeWriteRepoHook )
2019-04-17 08:31:08 +03:00
urlStr := fmt . Sprintf ( "/api/v1/repos/%s/%s/hooks/git/pre-receive?token=%s" ,
owner . Name , repo . Name , token )
req := NewRequestWithJSON ( t , "PATCH" , urlStr , & api . EditGitHookOption {
Content : testHookContent ,
} )
MakeRequest ( t , req , http . StatusForbidden )
}
func TestAPIDeleteGitHook ( t * testing . T ) {
2022-09-02 15:18:23 -04:00
defer tests . PrepareTestEnv ( t ) ( )
2019-04-17 08:31:08 +03:00
2022-08-16 10:22:25 +08:00
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : 37 } )
owner := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : repo . OwnerID } )
2019-04-17 08:31:08 +03:00
// user1 is an admin user
session := loginUser ( t , "user1" )
2023-01-17 16:46:03 -05:00
token := getTokenForLoggedInUser ( t , session , auth_model . AccessTokenScopeAdminRepoHook )
2019-04-17 08:31:08 +03:00
req := NewRequestf ( t , "DELETE" , "/api/v1/repos/%s/%s/hooks/git/pre-receive?token=%s" ,
owner . Name , repo . Name , token )
MakeRequest ( t , req , http . StatusNoContent )
req = NewRequestf ( t , "GET" , "/api/v1/repos/%s/%s/hooks/git/pre-receive?token=%s" ,
owner . Name , repo . Name , token )
resp := MakeRequest ( t , req , http . StatusOK )
var apiGitHook2 * api . GitHook
DecodeJSON ( t , resp , & apiGitHook2 )
assert . False ( t , apiGitHook2 . IsActive )
assert . Empty ( t , apiGitHook2 . Content )
}
func TestAPIDeleteGitHookNoAccess ( t * testing . T ) {
2022-09-02 15:18:23 -04:00
defer tests . PrepareTestEnv ( t ) ( )
2019-04-17 08:31:08 +03:00
2022-08-16 10:22:25 +08:00
repo := unittest . AssertExistsAndLoadBean ( t , & repo_model . Repository { ID : 1 } )
owner := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : repo . OwnerID } )
2019-04-17 08:31:08 +03:00
session := loginUser ( t , owner . Name )
2023-01-17 16:46:03 -05:00
token := getTokenForLoggedInUser ( t , session , auth_model . AccessTokenScopeWriteRepoHook )
2019-04-17 08:31:08 +03:00
req := NewRequestf ( t , "DELETE" , "/api/v1/repos/%s/%s/hooks/git/pre-receive?token=%s" ,
owner . Name , repo . Name , token )
MakeRequest ( t , req , http . StatusForbidden )
}