2021-01-10 15:14:02 +03:00
// Copyright 2021 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"
"strconv"
"testing"
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"
2021-01-10 15:14:02 +03:00
"github.com/stretchr/testify/assert"
)
func TestAdminViewUsers ( t * testing . T ) {
2021-08-27 16:00:37 +03:00
defer prepareTestEnv ( t ) ( )
2021-01-10 15:14:02 +03:00
session := loginUser ( t , "user1" )
req := NewRequest ( t , "GET" , "/admin/users" )
session . MakeRequest ( t , req , http . StatusOK )
session = loginUser ( t , "user2" )
req = NewRequest ( t , "GET" , "/admin/users" )
session . MakeRequest ( t , req , http . StatusForbidden )
}
func TestAdminViewUser ( t * testing . T ) {
2021-08-27 16:00:37 +03:00
defer prepareTestEnv ( t ) ( )
2021-01-10 15:14:02 +03:00
session := loginUser ( t , "user1" )
req := NewRequest ( t , "GET" , "/admin/users/1" )
session . MakeRequest ( t , req , http . StatusOK )
session = loginUser ( t , "user2" )
req = NewRequest ( t , "GET" , "/admin/users/1" )
session . MakeRequest ( t , req , http . StatusForbidden )
}
func TestAdminEditUser ( t * testing . T ) {
2021-08-27 16:00:37 +03:00
defer prepareTestEnv ( t ) ( )
2021-01-10 15:14:02 +03:00
2021-11-24 12:49:20 +03:00
testSuccessfullEdit ( t , user_model . User { ID : 2 , Name : "newusername" , LoginName : "otherlogin" , Email : "new@e-mail.gitea" } )
2021-01-10 15:14:02 +03:00
}
2021-11-24 12:49:20 +03:00
func testSuccessfullEdit ( t * testing . T , formData user_model . User ) {
2021-01-10 15:14:02 +03:00
makeRequest ( t , formData , http . StatusFound )
}
2021-11-24 12:49:20 +03:00
func makeRequest ( t * testing . T , formData user_model . User , headerCode int ) {
2021-01-10 15:14:02 +03:00
session := loginUser ( t , "user1" )
csrf := GetCSRF ( t , session , "/admin/users/" + strconv . Itoa ( int ( formData . ID ) ) )
req := NewRequestWithValues ( t , "POST" , "/admin/users/" + strconv . Itoa ( int ( formData . ID ) ) , map [ string ] string {
"_csrf" : csrf ,
"user_name" : formData . Name ,
"login_name" : formData . LoginName ,
"login_type" : "0-0" ,
"email" : formData . Email ,
} )
session . MakeRequest ( t , req , headerCode )
2021-11-24 12:49:20 +03:00
user := unittest . AssertExistsAndLoadBean ( t , & user_model . User { ID : formData . ID } ) . ( * user_model . User )
2021-01-10 15:14:02 +03:00
assert . Equal ( t , formData . Name , user . Name )
assert . Equal ( t , formData . LoginName , user . LoginName )
assert . Equal ( t , formData . Email , user . Email )
}
func TestAdminDeleteUser ( t * testing . T ) {
defer prepareTestEnv ( t ) ( )
session := loginUser ( t , "user1" )
csrf := GetCSRF ( t , session , "/admin/users/8" )
req := NewRequestWithValues ( t , "POST" , "/admin/users/8/delete" , map [ string ] string {
"_csrf" : csrf ,
} )
session . MakeRequest ( t , req , http . StatusOK )
assertUserDeleted ( t , 8 )
2021-11-24 12:49:20 +03:00
unittest . CheckConsistencyFor ( t , & user_model . User { } )
2021-01-10 15:14:02 +03:00
}