2017-02-02 20:33:36 +08: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 models
import (
2019-08-02 18:06:28 +02:00
"fmt"
2018-01-08 23:28:18 +01:00
"math/rand"
2019-01-24 14:12:17 +00:00
"strings"
2017-02-02 20:33:36 +08:00
"testing"
2017-02-14 20:16:00 +08:00
"code.gitea.io/gitea/modules/setting"
2017-10-25 01:36:19 +08:00
"code.gitea.io/gitea/modules/util"
2017-02-14 20:16:00 +08:00
2017-02-02 20:33:36 +08:00
"github.com/stretchr/testify/assert"
)
2019-08-02 18:06:28 +02:00
func TestUserIsPublicMember ( t * testing . T ) {
assert . NoError ( t , PrepareTestDatabase ( ) )
tt := [ ] struct {
uid int64
orgid int64
expected bool
} {
{ 2 , 3 , true } ,
{ 4 , 3 , false } ,
{ 5 , 6 , true } ,
{ 5 , 7 , false } ,
}
for _ , v := range tt {
t . Run ( fmt . Sprintf ( "UserId%dIsPublicMemberOf%d" , v . uid , v . orgid ) , func ( t * testing . T ) {
testUserIsPublicMember ( t , v . uid , v . orgid , v . expected )
} )
}
}
2021-03-15 02:52:12 +08:00
func testUserIsPublicMember ( t * testing . T , uid , orgID int64 , expected bool ) {
2019-08-02 18:06:28 +02:00
user , err := GetUserByID ( uid )
assert . NoError ( t , err )
assert . Equal ( t , expected , user . IsPublicMember ( orgID ) )
}
func TestIsUserOrgOwner ( t * testing . T ) {
assert . NoError ( t , PrepareTestDatabase ( ) )
tt := [ ] struct {
uid int64
orgid int64
expected bool
} {
{ 2 , 3 , true } ,
{ 4 , 3 , false } ,
{ 5 , 6 , true } ,
{ 5 , 7 , true } ,
}
for _ , v := range tt {
t . Run ( fmt . Sprintf ( "UserId%dIsOrgOwnerOf%d" , v . uid , v . orgid ) , func ( t * testing . T ) {
testIsUserOrgOwner ( t , v . uid , v . orgid , v . expected )
} )
}
}
2021-03-15 02:52:12 +08:00
func testIsUserOrgOwner ( t * testing . T , uid , orgID int64 , expected bool ) {
2019-08-02 18:06:28 +02:00
user , err := GetUserByID ( uid )
assert . NoError ( t , err )
assert . Equal ( t , expected , user . IsUserOrgOwner ( orgID ) )
}
2017-02-02 20:33:36 +08:00
func TestGetUserEmailsByNames ( t * testing . T ) {
assert . NoError ( t , PrepareTestDatabase ( ) )
// ignore none active user email
assert . Equal ( t , [ ] string { "user8@example.com" } , GetUserEmailsByNames ( [ ] string { "user8" , "user9" } ) )
assert . Equal ( t , [ ] string { "user8@example.com" , "user5@example.com" } , GetUserEmailsByNames ( [ ] string { "user8" , "user5" } ) )
2019-08-29 14:05:42 +00:00
assert . Equal ( t , [ ] string { "user8@example.com" } , GetUserEmailsByNames ( [ ] string { "user8" , "user7" } ) )
2017-02-02 20:33:36 +08:00
}
2017-02-14 20:16:00 +08:00
func TestCanCreateOrganization ( t * testing . T ) {
assert . NoError ( t , PrepareTestDatabase ( ) )
admin := AssertExistsAndLoadBean ( t , & User { ID : 1 } ) . ( * User )
assert . True ( t , admin . CanCreateOrganization ( ) )
user := AssertExistsAndLoadBean ( t , & User { ID : 2 } ) . ( * User )
assert . True ( t , user . CanCreateOrganization ( ) )
// Disable user create organization permission.
user . AllowCreateOrganization = false
assert . False ( t , user . CanCreateOrganization ( ) )
setting . Admin . DisableRegularOrgCreation = true
user . AllowCreateOrganization = true
assert . True ( t , admin . CanCreateOrganization ( ) )
assert . False ( t , user . CanCreateOrganization ( ) )
2017-05-20 04:48:22 -04:00
}
2017-10-25 01:36:19 +08:00
func TestSearchUsers ( t * testing . T ) {
assert . NoError ( t , PrepareTestDatabase ( ) )
testSuccess := func ( opts * SearchUserOptions , expectedUserOrOrgIDs [ ] int64 ) {
users , _ , err := SearchUsers ( opts )
assert . NoError ( t , err )
if assert . Len ( t , users , len ( expectedUserOrOrgIDs ) ) {
for i , expectedID := range expectedUserOrOrgIDs {
assert . EqualValues ( t , expectedID , users [ i ] . ID )
}
}
}
// test orgs
testOrgSuccess := func ( opts * SearchUserOptions , expectedOrgIDs [ ] int64 ) {
opts . Type = UserTypeOrganization
testSuccess ( opts , expectedOrgIDs )
}
2020-01-24 19:00:29 +00:00
testOrgSuccess ( & SearchUserOptions { OrderBy : "id ASC" , ListOptions : ListOptions { Page : 1 , PageSize : 2 } } ,
2017-10-25 01:36:19 +08:00
[ ] int64 { 3 , 6 } )
2020-01-24 19:00:29 +00:00
testOrgSuccess ( & SearchUserOptions { OrderBy : "id ASC" , ListOptions : ListOptions { Page : 2 , PageSize : 2 } } ,
2017-10-25 01:36:19 +08:00
[ ] int64 { 7 , 17 } )
2020-01-24 19:00:29 +00:00
testOrgSuccess ( & SearchUserOptions { OrderBy : "id ASC" , ListOptions : ListOptions { Page : 3 , PageSize : 2 } } ,
2019-08-02 18:06:28 +02:00
[ ] int64 { 19 , 25 } )
2017-10-26 23:16:13 +02:00
2020-01-24 19:00:29 +00:00
testOrgSuccess ( & SearchUserOptions { OrderBy : "id ASC" , ListOptions : ListOptions { Page : 4 , PageSize : 2 } } ,
2019-09-23 22:08:03 +02:00
[ ] int64 { 26 } )
2020-01-24 19:00:29 +00:00
testOrgSuccess ( & SearchUserOptions { ListOptions : ListOptions { Page : 5 , PageSize : 2 } } ,
2017-10-25 01:36:19 +08:00
[ ] int64 { } )
// test users
testUserSuccess := func ( opts * SearchUserOptions , expectedUserIDs [ ] int64 ) {
opts . Type = UserTypeIndividual
testSuccess ( opts , expectedUserIDs )
}
2020-01-24 19:00:29 +00:00
testUserSuccess ( & SearchUserOptions { OrderBy : "id ASC" , ListOptions : ListOptions { Page : 1 } } ,
2021-01-13 05:19:17 +01:00
[ ] int64 { 1 , 2 , 4 , 5 , 8 , 9 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 18 , 20 , 21 , 24 , 27 , 28 , 29 , 30 } )
2017-10-25 01:36:19 +08:00
2020-01-24 19:00:29 +00:00
testUserSuccess ( & SearchUserOptions { ListOptions : ListOptions { Page : 1 } , IsActive : util . OptionalBoolFalse } ,
2017-10-25 01:36:19 +08:00
[ ] int64 { 9 } )
2020-01-24 19:00:29 +00:00
testUserSuccess ( & SearchUserOptions { OrderBy : "id ASC" , ListOptions : ListOptions { Page : 1 } , IsActive : util . OptionalBoolTrue } ,
2021-01-13 05:19:17 +01:00
[ ] int64 { 1 , 2 , 4 , 5 , 8 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 18 , 20 , 21 , 24 , 28 , 29 , 30 } )
2017-10-25 01:36:19 +08:00
2020-01-24 19:00:29 +00:00
testUserSuccess ( & SearchUserOptions { Keyword : "user1" , OrderBy : "id ASC" , ListOptions : ListOptions { Page : 1 } , IsActive : util . OptionalBoolTrue } ,
2017-10-25 01:36:19 +08:00
[ ] int64 { 1 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 18 } )
// order by name asc default
2020-01-24 19:00:29 +00:00
testUserSuccess ( & SearchUserOptions { Keyword : "user1" , ListOptions : ListOptions { Page : 1 } , IsActive : util . OptionalBoolTrue } ,
2017-10-25 01:36:19 +08:00
[ ] int64 { 1 , 10 , 11 , 12 , 13 , 14 , 15 , 16 , 18 } )
}
2017-05-20 04:48:22 -04:00
func TestDeleteUser ( t * testing . T ) {
test := func ( userID int64 ) {
assert . NoError ( t , PrepareTestDatabase ( ) )
user := AssertExistsAndLoadBean ( t , & User { ID : userID } ) . ( * User )
ownedRepos := make ( [ ] * Repository , 0 , 10 )
assert . NoError ( t , x . Find ( & ownedRepos , & Repository { OwnerID : userID } ) )
if len ( ownedRepos ) > 0 {
err := DeleteUser ( user )
assert . Error ( t , err )
assert . True ( t , IsErrUserOwnRepos ( err ) )
return
}
2017-02-14 20:16:00 +08:00
2017-05-20 04:48:22 -04:00
orgUsers := make ( [ ] * OrgUser , 0 , 10 )
assert . NoError ( t , x . Find ( & orgUsers , & OrgUser { UID : userID } ) )
for _ , orgUser := range orgUsers {
if err := RemoveOrgUser ( orgUser . OrgID , orgUser . UID ) ; err != nil {
assert . True ( t , IsErrLastOrgOwner ( err ) )
return
}
}
assert . NoError ( t , DeleteUser ( user ) )
AssertNotExistsBean ( t , & User { ID : userID } )
CheckConsistencyFor ( t , & User { } , & Repository { } )
}
test ( 2 )
test ( 4 )
test ( 8 )
test ( 11 )
2020-02-04 15:27:18 +01:00
org := AssertExistsAndLoadBean ( t , & User { ID : 3 } ) . ( * User )
assert . Error ( t , DeleteUser ( org ) )
2017-02-14 20:16:00 +08:00
}
2018-01-08 23:28:18 +01:00
2019-08-29 14:05:42 +00:00
func TestEmailNotificationPreferences ( t * testing . T ) {
assert . NoError ( t , PrepareTestDatabase ( ) )
for _ , test := range [ ] struct {
expected string
userID int64
} {
{ EmailNotificationsEnabled , 1 } ,
{ EmailNotificationsEnabled , 2 } ,
{ EmailNotificationsOnMention , 3 } ,
{ EmailNotificationsOnMention , 4 } ,
{ EmailNotificationsEnabled , 5 } ,
{ EmailNotificationsEnabled , 6 } ,
{ EmailNotificationsDisabled , 7 } ,
{ EmailNotificationsEnabled , 8 } ,
{ EmailNotificationsOnMention , 9 } ,
} {
user := AssertExistsAndLoadBean ( t , & User { ID : test . userID } ) . ( * User )
assert . Equal ( t , test . expected , user . EmailNotifications ( ) )
// Try all possible settings
assert . NoError ( t , user . SetEmailNotifications ( EmailNotificationsEnabled ) )
assert . Equal ( t , EmailNotificationsEnabled , user . EmailNotifications ( ) )
assert . NoError ( t , user . SetEmailNotifications ( EmailNotificationsOnMention ) )
assert . Equal ( t , EmailNotificationsOnMention , user . EmailNotifications ( ) )
assert . NoError ( t , user . SetEmailNotifications ( EmailNotificationsDisabled ) )
assert . Equal ( t , EmailNotificationsDisabled , user . EmailNotifications ( ) )
}
}
2018-01-08 23:28:18 +01:00
func TestHashPasswordDeterministic ( t * testing . T ) {
b := make ( [ ] byte , 16 )
2021-01-10 19:05:18 +01:00
u := & User { }
2020-09-03 19:58:31 +01:00
algos := [ ] string { "argon2" , "pbkdf2" , "scrypt" , "bcrypt" }
2019-07-07 08:01:01 +02:00
for j := 0 ; j < len ( algos ) ; j ++ {
u . PasswdHashAlgo = algos [ j ]
for i := 0 ; i < 50 ; i ++ {
// generate a random password
rand . Read ( b )
pass := string ( b )
// save the current password in the user - hash it and store the result
2021-01-10 19:05:18 +01:00
u . SetPassword ( pass )
2019-07-07 08:01:01 +02:00
r1 := u . Passwd
// run again
2021-01-10 19:05:18 +01:00
u . SetPassword ( pass )
2019-07-07 08:01:01 +02:00
r2 := u . Passwd
2021-01-10 19:05:18 +01:00
assert . NotEqual ( t , r1 , r2 )
assert . True ( t , u . ValidatePassword ( pass ) )
2019-07-07 08:01:01 +02:00
}
2018-01-08 23:28:18 +01:00
}
}
func BenchmarkHashPassword ( b * testing . B ) {
// BenchmarkHashPassword ensures that it takes a reasonable amount of time
// to hash a password - in order to protect from brute-force attacks.
pass := "password1337"
2021-01-10 19:05:18 +01:00
u := & User { Passwd : pass }
2018-01-08 23:28:18 +01:00
b . ResetTimer ( )
for i := 0 ; i < b . N ; i ++ {
2021-01-10 19:05:18 +01:00
u . SetPassword ( pass )
2018-01-08 23:28:18 +01:00
}
}
2018-06-21 18:00:13 +02:00
2019-10-09 01:55:16 +08:00
func TestGetOrgRepositoryIDs ( t * testing . T ) {
assert . NoError ( t , PrepareTestDatabase ( ) )
user2 := AssertExistsAndLoadBean ( t , & User { ID : 2 } ) . ( * User )
user4 := AssertExistsAndLoadBean ( t , & User { ID : 4 } ) . ( * User )
user5 := AssertExistsAndLoadBean ( t , & User { ID : 5 } ) . ( * User )
accessibleRepos , err := user2 . GetOrgRepositoryIDs ( )
assert . NoError ( t , err )
// User 2's team has access to private repos 3, 5, repo 32 is a public repo of the organization
assert . Equal ( t , [ ] int64 { 3 , 5 , 23 , 24 , 32 } , accessibleRepos )
accessibleRepos , err = user4 . GetOrgRepositoryIDs ( )
assert . NoError ( t , err )
// User 4's team has access to private repo 3, repo 32 is a public repo of the organization
assert . Equal ( t , [ ] int64 { 3 , 32 } , accessibleRepos )
accessibleRepos , err = user5 . GetOrgRepositoryIDs ( )
assert . NoError ( t , err )
// User 5's team has no access to any repo
assert . Len ( t , accessibleRepos , 0 )
}
2019-01-24 14:12:17 +00:00
func TestNewGitSig ( t * testing . T ) {
users := make ( [ ] * User , 0 , 20 )
sess := x . NewSession ( )
defer sess . Close ( )
sess . Find ( & users )
for _ , user := range users {
sig := user . NewGitSig ( )
assert . NotContains ( t , sig . Name , "<" )
assert . NotContains ( t , sig . Name , ">" )
assert . NotContains ( t , sig . Name , "\n" )
assert . NotEqual ( t , len ( strings . TrimSpace ( sig . Name ) ) , 0 )
}
}
func TestDisplayName ( t * testing . T ) {
users := make ( [ ] * User , 0 , 20 )
sess := x . NewSession ( )
defer sess . Close ( )
sess . Find ( & users )
for _ , user := range users {
displayName := user . DisplayName ( )
assert . Equal ( t , strings . TrimSpace ( displayName ) , displayName )
if len ( strings . TrimSpace ( user . FullName ) ) == 0 {
assert . Equal ( t , user . Name , displayName )
}
assert . NotEqual ( t , len ( strings . TrimSpace ( displayName ) ) , 0 )
}
}
2019-01-30 18:04:14 +01:00
func TestCreateUser ( t * testing . T ) {
user := & User {
Name : "GiteaBot" ,
Email : "GiteaBot@gitea.io" ,
Passwd : ";p['////..-++']" ,
IsAdmin : false ,
Theme : setting . UI . DefaultTheme ,
MustChangePassword : false ,
}
assert . NoError ( t , CreateUser ( user ) )
assert . NoError ( t , DeleteUser ( user ) )
}
2020-11-15 00:53:43 +08:00
func TestCreateUserInvalidEmail ( t * testing . T ) {
user := & User {
Name : "GiteaBot" ,
Email : "GiteaBot@gitea.io\r\n" ,
Passwd : ";p['////..-++']" ,
IsAdmin : false ,
Theme : setting . UI . DefaultTheme ,
MustChangePassword : false ,
}
err := CreateUser ( user )
assert . Error ( t , err )
assert . True ( t , IsErrEmailInvalid ( err ) )
}
2019-01-30 18:04:14 +01:00
func TestCreateUser_Issue5882 ( t * testing . T ) {
// Init settings
_ = setting . Admin
passwd := ".//.;1;;//.,-=_"
tt := [ ] struct {
user * User
disableOrgCreation bool
} {
{ & User { Name : "GiteaBot" , Email : "GiteaBot@gitea.io" , Passwd : passwd , MustChangePassword : false } , false } ,
{ & User { Name : "GiteaBot2" , Email : "GiteaBot2@gitea.io" , Passwd : passwd , MustChangePassword : false } , true } ,
}
2019-05-24 18:40:45 +02:00
setting . Service . DefaultAllowCreateOrganization = true
2019-01-30 18:04:14 +01:00
for _ , v := range tt {
setting . Admin . DisableRegularOrgCreation = v . disableOrgCreation
assert . NoError ( t , CreateUser ( v . user ) )
u , err := GetUserByEmail ( v . user . Email )
assert . NoError ( t , err )
assert . Equal ( t , ! u . AllowCreateOrganization , v . disableOrgCreation )
assert . NoError ( t , DeleteUser ( v . user ) )
}
}
2019-11-10 09:07:21 +01:00
func TestGetUserIDsByNames ( t * testing . T ) {
2021-05-12 06:13:42 +02:00
assert . NoError ( t , PrepareTestDatabase ( ) )
2021-03-15 02:52:12 +08:00
// ignore non existing
2019-11-10 09:07:21 +01:00
IDs , err := GetUserIDsByNames ( [ ] string { "user1" , "user2" , "none_existing_user" } , true )
assert . NoError ( t , err )
assert . Equal ( t , [ ] int64 { 1 , 2 } , IDs )
2021-03-15 02:52:12 +08:00
// ignore non existing
2019-11-10 09:07:21 +01:00
IDs , err = GetUserIDsByNames ( [ ] string { "user1" , "do_not_exist" } , false )
assert . Error ( t , err )
assert . Equal ( t , [ ] int64 ( nil ) , IDs )
}
2020-09-10 03:08:55 +08:00
func TestGetMaileableUsersByIDs ( t * testing . T ) {
2021-05-12 06:13:42 +02:00
assert . NoError ( t , PrepareTestDatabase ( ) )
2020-09-10 03:08:55 +08:00
results , err := GetMaileableUsersByIDs ( [ ] int64 { 1 , 4 } , false )
assert . NoError ( t , err )
2021-06-07 07:27:09 +02:00
assert . Len ( t , results , 1 )
2020-09-10 03:08:55 +08:00
if len ( results ) > 1 {
assert . Equal ( t , results [ 0 ] . ID , 1 )
}
results , err = GetMaileableUsersByIDs ( [ ] int64 { 1 , 4 } , true )
assert . NoError ( t , err )
2021-06-07 07:27:09 +02:00
assert . Len ( t , results , 2 )
2020-09-10 03:08:55 +08:00
if len ( results ) > 2 {
assert . Equal ( t , results [ 0 ] . ID , 1 )
assert . Equal ( t , results [ 1 ] . ID , 4 )
}
}
2020-12-18 17:44:18 +00:00
func TestAddLdapSSHPublicKeys ( t * testing . T ) {
assert . NoError ( t , PrepareTestDatabase ( ) )
user := AssertExistsAndLoadBean ( t , & User { ID : 2 } ) . ( * User )
s := & LoginSource { ID : 1 }
testCases := [ ] struct {
keyString string
number int
keyContents [ ] string
} {
{
keyString : "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC4cn+iXnA4KvcQYSV88vGn0Yi91vG47t1P7okprVmhNTkipNRIHWr6WdCO4VDr/cvsRkuVJAsLO2enwjGWWueOO6BodiBgyAOZ/5t5nJNMCNuLGT5UIo/RI1b0WRQwxEZTRjt6mFNw6lH14wRd8ulsr9toSWBPMOGWoYs1PDeDL0JuTjL+tr1SZi/EyxCngpYszKdXllJEHyI79KQgeD0Vt3pTrkbNVTOEcCNqZePSVmUH8X8Vhugz3bnE0/iE9Pb5fkWO9c4AnM1FgI/8Bvp27Fw2ShryIXuR6kKvUqhVMTuOSDHwu6A8jLE5Owt3GAYugDpDYuwTVNGrHLXKpPzrGGPE/jPmaLCMZcsdkec95dYeU3zKODEm8UQZFhmJmDeWVJ36nGrGZHL4J5aTTaeFUJmmXDaJYiJ+K2/ioKgXqnXvltu0A9R8/LGy4nrTJRr4JMLuJFoUXvGm1gXQ70w2LSpk6yl71RNC0hCtsBe8BP8IhYCM0EP5jh7eCMQZNvM= nocomment\n" ,
number : 1 ,
keyContents : [ ] string {
"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC4cn+iXnA4KvcQYSV88vGn0Yi91vG47t1P7okprVmhNTkipNRIHWr6WdCO4VDr/cvsRkuVJAsLO2enwjGWWueOO6BodiBgyAOZ/5t5nJNMCNuLGT5UIo/RI1b0WRQwxEZTRjt6mFNw6lH14wRd8ulsr9toSWBPMOGWoYs1PDeDL0JuTjL+tr1SZi/EyxCngpYszKdXllJEHyI79KQgeD0Vt3pTrkbNVTOEcCNqZePSVmUH8X8Vhugz3bnE0/iE9Pb5fkWO9c4AnM1FgI/8Bvp27Fw2ShryIXuR6kKvUqhVMTuOSDHwu6A8jLE5Owt3GAYugDpDYuwTVNGrHLXKpPzrGGPE/jPmaLCMZcsdkec95dYeU3zKODEm8UQZFhmJmDeWVJ36nGrGZHL4J5aTTaeFUJmmXDaJYiJ+K2/ioKgXqnXvltu0A9R8/LGy4nrTJRr4JMLuJFoUXvGm1gXQ70w2LSpk6yl71RNC0hCtsBe8BP8IhYCM0EP5jh7eCMQZNvM=" ,
} ,
} ,
{
keyString : ` ssh - rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC4cn + iXnA4KvcQYSV88vGn0Yi91vG47t1P7okprVmhNTkipNRIHWr6WdCO4VDr / cvsRkuVJAsLO2enwjGWWueOO6BodiBgyAOZ / 5 t5nJNMCNuLGT5UIo / RI1b0WRQwxEZTRjt6mFNw6lH14wRd8ulsr9toSWBPMOGWoYs1PDeDL0JuTjL + tr1SZi / EyxCngpYszKdXllJEHyI79KQgeD0Vt3pTrkbNVTOEcCNqZePSVmUH8X8Vhugz3bnE0 / iE9Pb5fkWO9c4AnM1FgI / 8 Bvp27Fw2ShryIXuR6kKvUqhVMTuOSDHwu6A8jLE5Owt3GAYugDpDYuwTVNGrHLXKpPzrGGPE / jPmaLCMZcsdkec95dYeU3zKODEm8UQZFhmJmDeWVJ36nGrGZHL4J5aTTaeFUJmmXDaJYiJ + K2 / ioKgXqnXvltu0A9R8 / LGy4nrTJRr4JMLuJFoUXvGm1gXQ70w2LSpk6yl71RNC0hCtsBe8BP8IhYCM0EP5jh7eCMQZNvM = nocomment
ssh - dss AAAAB3NzaC1kc3MAAACBAOChCC7lf6Uo9n7BmZ6M8St19PZf4Tn59NriyboW2x / DZuYAz3ibZ2OkQ3S0SqDIa0HXSEJ1zaExQdmbO + Ux / wsytWZmCczWOVsaszBZSl90q8UnWlSH6P + / YA + RWJm5SFtuV9PtGIhyZgoNuz5kBQ7K139wuQsecdKktISwTakzAAAAFQCzKsO2JhNKlL + wwwLGOcLffoAmkwAAAIBpK7 / 3 xvduajLBD / 9 vASqBQIHrgK2J + wiQnIb / Wzy0UsVmvfn8A + udRbBo + csM8xrSnlnlJnjkJS3qiM5g + eTwsLIV1IdKPEwmwB + VcP53Cw6lSyWyJcvhFb0N6s08NZysLzvj0N + ZC / FnhKTLzIyMtkHf / IrPCwlM + pV / M / 96 YgAAAIEAqQcGn9CKgzgPaguIZooTAOQdvBLMI5y0bQjOW6734XOpqQGf / Kra90wpoasLKZjSYKNPjE + FRUOrStLrxcNs4BeVKhy2PYTRnybfYVk1 / dmKgH6P1YSRONsGKvTsH6c5IyCRG0ncCgYeF8tXppyd642982daopE7zQ / NPAnJfag = nocomment ` ,
number : 2 ,
keyContents : [ ] string {
"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC4cn+iXnA4KvcQYSV88vGn0Yi91vG47t1P7okprVmhNTkipNRIHWr6WdCO4VDr/cvsRkuVJAsLO2enwjGWWueOO6BodiBgyAOZ/5t5nJNMCNuLGT5UIo/RI1b0WRQwxEZTRjt6mFNw6lH14wRd8ulsr9toSWBPMOGWoYs1PDeDL0JuTjL+tr1SZi/EyxCngpYszKdXllJEHyI79KQgeD0Vt3pTrkbNVTOEcCNqZePSVmUH8X8Vhugz3bnE0/iE9Pb5fkWO9c4AnM1FgI/8Bvp27Fw2ShryIXuR6kKvUqhVMTuOSDHwu6A8jLE5Owt3GAYugDpDYuwTVNGrHLXKpPzrGGPE/jPmaLCMZcsdkec95dYeU3zKODEm8UQZFhmJmDeWVJ36nGrGZHL4J5aTTaeFUJmmXDaJYiJ+K2/ioKgXqnXvltu0A9R8/LGy4nrTJRr4JMLuJFoUXvGm1gXQ70w2LSpk6yl71RNC0hCtsBe8BP8IhYCM0EP5jh7eCMQZNvM=" ,
"ssh-dss AAAAB3NzaC1kc3MAAACBAOChCC7lf6Uo9n7BmZ6M8St19PZf4Tn59NriyboW2x/DZuYAz3ibZ2OkQ3S0SqDIa0HXSEJ1zaExQdmbO+Ux/wsytWZmCczWOVsaszBZSl90q8UnWlSH6P+/YA+RWJm5SFtuV9PtGIhyZgoNuz5kBQ7K139wuQsecdKktISwTakzAAAAFQCzKsO2JhNKlL+wwwLGOcLffoAmkwAAAIBpK7/3xvduajLBD/9vASqBQIHrgK2J+wiQnIb/Wzy0UsVmvfn8A+udRbBo+csM8xrSnlnlJnjkJS3qiM5g+eTwsLIV1IdKPEwmwB+VcP53Cw6lSyWyJcvhFb0N6s08NZysLzvj0N+ZC/FnhKTLzIyMtkHf/IrPCwlM+pV/M/96YgAAAIEAqQcGn9CKgzgPaguIZooTAOQdvBLMI5y0bQjOW6734XOpqQGf/Kra90wpoasLKZjSYKNPjE+FRUOrStLrxcNs4BeVKhy2PYTRnybfYVk1/dmKgH6P1YSRONsGKvTsH6c5IyCRG0ncCgYeF8tXppyd642982daopE7zQ/NPAnJfag=" ,
} ,
} ,
{
keyString : ` ssh - rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC4cn + iXnA4KvcQYSV88vGn0Yi91vG47t1P7okprVmhNTkipNRIHWr6WdCO4VDr / cvsRkuVJAsLO2enwjGWWueOO6BodiBgyAOZ / 5 t5nJNMCNuLGT5UIo / RI1b0WRQwxEZTRjt6mFNw6lH14wRd8ulsr9toSWBPMOGWoYs1PDeDL0JuTjL + tr1SZi / EyxCngpYszKdXllJEHyI79KQgeD0Vt3pTrkbNVTOEcCNqZePSVmUH8X8Vhugz3bnE0 / iE9Pb5fkWO9c4AnM1FgI / 8 Bvp27Fw2ShryIXuR6kKvUqhVMTuOSDHwu6A8jLE5Owt3GAYugDpDYuwTVNGrHLXKpPzrGGPE / jPmaLCMZcsdkec95dYeU3zKODEm8UQZFhmJmDeWVJ36nGrGZHL4J5aTTaeFUJmmXDaJYiJ + K2 / ioKgXqnXvltu0A9R8 / LGy4nrTJRr4JMLuJFoUXvGm1gXQ70w2LSpk6yl71RNC0hCtsBe8BP8IhYCM0EP5jh7eCMQZNvM = nocomment
# comment asmdna , ndp
ssh - dss AAAAB3NzaC1kc3MAAACBAOChCC7lf6Uo9n7BmZ6M8St19PZf4Tn59NriyboW2x / DZuYAz3ibZ2OkQ3S0SqDIa0HXSEJ1zaExQdmbO + Ux / wsytWZmCczWOVsaszBZSl90q8UnWlSH6P + / YA + RWJm5SFtuV9PtGIhyZgoNuz5kBQ7K139wuQsecdKktISwTakzAAAAFQCzKsO2JhNKlL + wwwLGOcLffoAmkwAAAIBpK7 / 3 xvduajLBD / 9 vASqBQIHrgK2J + wiQnIb / Wzy0UsVmvfn8A + udRbBo + csM8xrSnlnlJnjkJS3qiM5g + eTwsLIV1IdKPEwmwB + VcP53Cw6lSyWyJcvhFb0N6s08NZysLzvj0N + ZC / FnhKTLzIyMtkHf / IrPCwlM + pV / M / 96 YgAAAIEAqQcGn9CKgzgPaguIZooTAOQdvBLMI5y0bQjOW6734XOpqQGf / Kra90wpoasLKZjSYKNPjE + FRUOrStLrxcNs4BeVKhy2PYTRnybfYVk1 / dmKgH6P1YSRONsGKvTsH6c5IyCRG0ncCgYeF8tXppyd642982daopE7zQ / NPAnJfag = nocomment ` ,
number : 2 ,
keyContents : [ ] string {
"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC4cn+iXnA4KvcQYSV88vGn0Yi91vG47t1P7okprVmhNTkipNRIHWr6WdCO4VDr/cvsRkuVJAsLO2enwjGWWueOO6BodiBgyAOZ/5t5nJNMCNuLGT5UIo/RI1b0WRQwxEZTRjt6mFNw6lH14wRd8ulsr9toSWBPMOGWoYs1PDeDL0JuTjL+tr1SZi/EyxCngpYszKdXllJEHyI79KQgeD0Vt3pTrkbNVTOEcCNqZePSVmUH8X8Vhugz3bnE0/iE9Pb5fkWO9c4AnM1FgI/8Bvp27Fw2ShryIXuR6kKvUqhVMTuOSDHwu6A8jLE5Owt3GAYugDpDYuwTVNGrHLXKpPzrGGPE/jPmaLCMZcsdkec95dYeU3zKODEm8UQZFhmJmDeWVJ36nGrGZHL4J5aTTaeFUJmmXDaJYiJ+K2/ioKgXqnXvltu0A9R8/LGy4nrTJRr4JMLuJFoUXvGm1gXQ70w2LSpk6yl71RNC0hCtsBe8BP8IhYCM0EP5jh7eCMQZNvM=" ,
"ssh-dss AAAAB3NzaC1kc3MAAACBAOChCC7lf6Uo9n7BmZ6M8St19PZf4Tn59NriyboW2x/DZuYAz3ibZ2OkQ3S0SqDIa0HXSEJ1zaExQdmbO+Ux/wsytWZmCczWOVsaszBZSl90q8UnWlSH6P+/YA+RWJm5SFtuV9PtGIhyZgoNuz5kBQ7K139wuQsecdKktISwTakzAAAAFQCzKsO2JhNKlL+wwwLGOcLffoAmkwAAAIBpK7/3xvduajLBD/9vASqBQIHrgK2J+wiQnIb/Wzy0UsVmvfn8A+udRbBo+csM8xrSnlnlJnjkJS3qiM5g+eTwsLIV1IdKPEwmwB+VcP53Cw6lSyWyJcvhFb0N6s08NZysLzvj0N+ZC/FnhKTLzIyMtkHf/IrPCwlM+pV/M/96YgAAAIEAqQcGn9CKgzgPaguIZooTAOQdvBLMI5y0bQjOW6734XOpqQGf/Kra90wpoasLKZjSYKNPjE+FRUOrStLrxcNs4BeVKhy2PYTRnybfYVk1/dmKgH6P1YSRONsGKvTsH6c5IyCRG0ncCgYeF8tXppyd642982daopE7zQ/NPAnJfag=" ,
} ,
} ,
{
keyString : ` ssh - rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC4cn + iXnA4KvcQYSV88vGn0Yi91vG47t1P7okprVmhNTkipNRIHWr6WdCO4VDr / cvsRkuVJAsLO2enwjGWWueOO6BodiBgyAOZ / 5 t5nJNMCNuLGT5UIo / RI1b0WRQwxEZTRjt6mFNw6lH14wRd8ulsr9toSWBPMOGWoYs1PDeDL0JuTjL + tr1SZi / EyxCngpYszKdXllJEHyI79KQgeD0Vt3pTrkbNVTOEcCNqZePSVmUH8X8Vhugz3bnE0 / iE9Pb5fkWO9c4AnM1FgI / 8 Bvp27Fw2ShryIXuR6kKvUqhVMTuOSDHwu6A8jLE5Owt3GAYugDpDYuwTVNGrHLXKpPzrGGPE / jPmaLCMZcsdkec95dYeU3zKODEm8UQZFhmJmDeWVJ36nGrGZHL4J5aTTaeFUJmmXDaJYiJ + K2 / ioKgXqnXvltu0A9R8 / LGy4nrTJRr4JMLuJFoUXvGm1gXQ70w2LSpk6yl71RNC0hCtsBe8BP8IhYCM0EP5jh7eCMQZNvM = nocomment
382488320 jasdj1lasmva / vasodifipi4193 - fksma . cm
ssh - dss AAAAB3NzaC1kc3MAAACBAOChCC7lf6Uo9n7BmZ6M8St19PZf4Tn59NriyboW2x / DZuYAz3ibZ2OkQ3S0SqDIa0HXSEJ1zaExQdmbO + Ux / wsytWZmCczWOVsaszBZSl90q8UnWlSH6P + / YA + RWJm5SFtuV9PtGIhyZgoNuz5kBQ7K139wuQsecdKktISwTakzAAAAFQCzKsO2JhNKlL + wwwLGOcLffoAmkwAAAIBpK7 / 3 xvduajLBD / 9 vASqBQIHrgK2J + wiQnIb / Wzy0UsVmvfn8A + udRbBo + csM8xrSnlnlJnjkJS3qiM5g + eTwsLIV1IdKPEwmwB + VcP53Cw6lSyWyJcvhFb0N6s08NZysLzvj0N + ZC / FnhKTLzIyMtkHf / IrPCwlM + pV / M / 96 YgAAAIEAqQcGn9CKgzgPaguIZooTAOQdvBLMI5y0bQjOW6734XOpqQGf / Kra90wpoasLKZjSYKNPjE + FRUOrStLrxcNs4BeVKhy2PYTRnybfYVk1 / dmKgH6P1YSRONsGKvTsH6c5IyCRG0ncCgYeF8tXppyd642982daopE7zQ / NPAnJfag = nocomment ` ,
number : 2 ,
keyContents : [ ] string {
"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC4cn+iXnA4KvcQYSV88vGn0Yi91vG47t1P7okprVmhNTkipNRIHWr6WdCO4VDr/cvsRkuVJAsLO2enwjGWWueOO6BodiBgyAOZ/5t5nJNMCNuLGT5UIo/RI1b0WRQwxEZTRjt6mFNw6lH14wRd8ulsr9toSWBPMOGWoYs1PDeDL0JuTjL+tr1SZi/EyxCngpYszKdXllJEHyI79KQgeD0Vt3pTrkbNVTOEcCNqZePSVmUH8X8Vhugz3bnE0/iE9Pb5fkWO9c4AnM1FgI/8Bvp27Fw2ShryIXuR6kKvUqhVMTuOSDHwu6A8jLE5Owt3GAYugDpDYuwTVNGrHLXKpPzrGGPE/jPmaLCMZcsdkec95dYeU3zKODEm8UQZFhmJmDeWVJ36nGrGZHL4J5aTTaeFUJmmXDaJYiJ+K2/ioKgXqnXvltu0A9R8/LGy4nrTJRr4JMLuJFoUXvGm1gXQ70w2LSpk6yl71RNC0hCtsBe8BP8IhYCM0EP5jh7eCMQZNvM=" ,
"ssh-dss AAAAB3NzaC1kc3MAAACBAOChCC7lf6Uo9n7BmZ6M8St19PZf4Tn59NriyboW2x/DZuYAz3ibZ2OkQ3S0SqDIa0HXSEJ1zaExQdmbO+Ux/wsytWZmCczWOVsaszBZSl90q8UnWlSH6P+/YA+RWJm5SFtuV9PtGIhyZgoNuz5kBQ7K139wuQsecdKktISwTakzAAAAFQCzKsO2JhNKlL+wwwLGOcLffoAmkwAAAIBpK7/3xvduajLBD/9vASqBQIHrgK2J+wiQnIb/Wzy0UsVmvfn8A+udRbBo+csM8xrSnlnlJnjkJS3qiM5g+eTwsLIV1IdKPEwmwB+VcP53Cw6lSyWyJcvhFb0N6s08NZysLzvj0N+ZC/FnhKTLzIyMtkHf/IrPCwlM+pV/M/96YgAAAIEAqQcGn9CKgzgPaguIZooTAOQdvBLMI5y0bQjOW6734XOpqQGf/Kra90wpoasLKZjSYKNPjE+FRUOrStLrxcNs4BeVKhy2PYTRnybfYVk1/dmKgH6P1YSRONsGKvTsH6c5IyCRG0ncCgYeF8tXppyd642982daopE7zQ/NPAnJfag=" ,
} ,
} ,
}
for i , kase := range testCases {
s . ID = int64 ( i ) + 20
addLdapSSHPublicKeys ( user , s , [ ] string { kase . keyString } )
keys , err := ListPublicLdapSSHKeys ( user . ID , s . ID )
assert . NoError ( t , err )
if err != nil {
continue
}
2021-06-07 07:27:09 +02:00
assert . Len ( t , keys , kase . number )
2020-12-18 17:44:18 +00:00
for _ , key := range keys {
assert . Contains ( t , kase . keyContents , key . Content )
}
for _ , key := range keys {
DeletePublicKey ( user , key . ID )
}
}
}