2018-07-07 04:54:30 +03:00
// Copyright 2018 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 (
"net/http"
"testing"
"code.gitea.io/gitea/models"
2019-05-11 13:21:34 +03:00
api "code.gitea.io/gitea/modules/structs"
2018-07-07 04:54:30 +03:00
)
// TestAPICreateAndDeleteToken tests that token that was just created can be deleted
func TestAPICreateAndDeleteToken ( t * testing . T ) {
2019-11-26 02:21:37 +03:00
defer prepareTestEnv ( t ) ( )
2018-07-07 04:54:30 +03:00
user := models . AssertExistsAndLoadBean ( t , & models . User { ID : 1 } ) . ( * models . User )
req := NewRequestWithJSON ( t , "POST" , "/api/v1/users/user1/tokens" , map [ string ] string {
"name" : "test-key-1" ,
} )
req = AddBasicAuthHeader ( req , user . Name )
resp := MakeRequest ( t , req , http . StatusCreated )
var newAccessToken api . AccessToken
DecodeJSON ( t , resp , & newAccessToken )
models . AssertExistsAndLoadBean ( t , & models . AccessToken {
2019-05-04 18:45:34 +03:00
ID : newAccessToken . ID ,
Name : newAccessToken . Name ,
Token : newAccessToken . Token ,
UID : user . ID ,
2018-07-07 04:54:30 +03:00
} )
req = NewRequestf ( t , "DELETE" , "/api/v1/users/user1/tokens/%d" , newAccessToken . ID )
req = AddBasicAuthHeader ( req , user . Name )
MakeRequest ( t , req , http . StatusNoContent )
models . AssertNotExistsBean ( t , & models . AccessToken { ID : newAccessToken . ID } )
}
// TestAPIDeleteMissingToken ensures that error is thrown when token not found
func TestAPIDeleteMissingToken ( t * testing . T ) {
2019-11-26 02:21:37 +03:00
defer prepareTestEnv ( t ) ( )
2018-07-07 04:54:30 +03:00
user := models . AssertExistsAndLoadBean ( t , & models . User { ID : 1 } ) . ( * models . User )
req := NewRequestf ( t , "DELETE" , "/api/v1/users/user1/tokens/%d" , models . NonexistentID )
req = AddBasicAuthHeader ( req , user . Name )
MakeRequest ( t , req , http . StatusNotFound )
}