Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
goSDN
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Iterations
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Locked files
Build
Pipelines
Jobs
Pipeline schedules
Test cases
Artifacts
Deploy
Releases
Package registry
Container registry
Model registry
Operate
Terraform modules
Analyze
Contributor analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
danet
goSDN
Merge requests
!308
Improve test coverage of rbac stuff
Code
Review changes
Check out branch
Download
Patches
Plain diff
Merged
Improve test coverage of rbac stuff
207-improve-test-coverage-of-rbac-stuff
into
develop
Overview
7
Commits
15
Pipelines
18
Changes
2
Merged
Ghost User
requested to merge
207-improve-test-coverage-of-rbac-stuff
into
develop
3 years ago
Overview
3
Commits
15
Pipelines
18
Changes
2
Expand
Description
Trying to improve coverage. 🥴
Related Issue
#207 (closed)
Edited
3 years ago
by
Ghost User
0
0
Merge request reports
Viewing commit
88a9c999
Show latest version
2 files
+
388
−
3
Inline
Compare changes
Side-by-side
Inline
Show whitespace changes
Show one file at a time
Files
2
Search (e.g. *.vue) (Ctrl+P)
88a9c999
added tests for api roles, minor style changes to other file
· 88a9c999
Fabian Seidl
authored
3 years ago
controller/api/role_test.go
0 → 100644
+
378
−
0
Options
package
api
import
(
"context"
"reflect"
"testing"
apb
"code.fbi.h-da.de/danet/gosdn/api/go/gosdn/rbac"
"github.com/google/uuid"
)
func
TestCreateRoles
(
t
*
testing
.
T
)
{
type
args
struct
{
ctx
context
.
Context
addr
string
roles
[]
*
apb
.
Role
}
tests
:=
[]
struct
{
name
string
args
args
want
*
apb
.
CreateRolesResponse
wantErr
bool
}{
{
name
:
"default create roles"
,
args
:
args
{
ctx
:
context
.
TODO
(),
addr
:
testAPIEndpoint
,
roles
:
[]
*
apb
.
Role
{
{
Name
:
"new role 1"
,
Description
:
"Role 1"
,
Permissions
:
[]
string
{
"permission 1"
,
"permission 2"
},
},
},
},
want
:
&
apb
.
CreateRolesResponse
{
Status
:
apb
.
Status_STATUS_OK
,
},
wantErr
:
false
,
},
}
for
_
,
tt
:=
range
tests
{
t
.
Run
(
tt
.
name
,
func
(
t
*
testing
.
T
)
{
got
,
err
:=
CreateRoles
(
tt
.
args
.
ctx
,
tt
.
args
.
addr
,
tt
.
args
.
roles
)
if
(
err
!=
nil
)
!=
tt
.
wantErr
{
t
.
Errorf
(
"CreateRoles() error = %v, wantErr %v"
,
err
,
tt
.
wantErr
)
return
}
if
got
!=
nil
&&
got
.
Status
!=
tt
.
want
.
Status
{
t
.
Errorf
(
"Role.CreateRoles() = %v, want %v"
,
got
,
tt
.
want
)
}
})
}
}
func
TestGetRole
(
t
*
testing
.
T
)
{
type
args
struct
{
ctx
context
.
Context
addr
string
name
string
}
tests
:=
[]
struct
{
name
string
args
args
want
*
apb
.
GetRoleResponse
wantErr
bool
}{
{
name
:
"default get role"
,
args
:
args
{
ctx
:
context
.
TODO
(),
addr
:
testAPIEndpoint
,
name
:
"adminTestRole"
,
},
want
:
&
apb
.
GetRoleResponse
{
Status
:
apb
.
Status_STATUS_OK
,
Role
:
&
apb
.
Role
{
Name
:
"adminTestRole"
,
Description
:
"Admin"
,
},
},
wantErr
:
false
,
},
{
name
:
"error get role"
,
args
:
args
{
ctx
:
context
.
TODO
(),
addr
:
testAPIEndpoint
,
name
:
"not role"
,
},
want
:
nil
,
wantErr
:
true
,
},
}
for
_
,
tt
:=
range
tests
{
t
.
Run
(
tt
.
name
,
func
(
t
*
testing
.
T
)
{
got
,
err
:=
GetRole
(
tt
.
args
.
ctx
,
tt
.
args
.
addr
,
tt
.
args
.
name
)
if
(
err
!=
nil
)
!=
tt
.
wantErr
{
t
.
Errorf
(
"GetRole() error = %v, wantErr %v"
,
err
,
tt
.
wantErr
)
return
}
if
got
!=
nil
&&
got
.
Status
==
tt
.
want
.
Status
{
if
got
.
Role
.
Name
!=
tt
.
want
.
Role
.
Name
||
got
.
Role
.
Description
!=
tt
.
want
.
Role
.
Description
{
t
.
Errorf
(
"Role.GetRole() = %v, want %v"
,
got
,
tt
.
want
)
}
}
else
{
if
got
!=
nil
{
t
.
Errorf
(
"Role.GetRole() = %v, want %v"
,
got
,
tt
.
want
)
}
}
})
}
}
func
TestGetRoles
(
t
*
testing
.
T
)
{
err
:=
clearAndCreateAuthTestSetup
()
if
err
!=
nil
{
t
.
Fatalf
(
"%v"
,
err
)
}
type
args
struct
{
ctx
context
.
Context
addr
string
}
tests
:=
[]
struct
{
name
string
args
args
want
*
apb
.
GetRolesResponse
wantLen
int
wantErr
bool
}{
{
name
:
"default get roless"
,
args
:
args
{
ctx
:
context
.
TODO
(),
addr
:
testAPIEndpoint
,
},
want
:
&
apb
.
GetRolesResponse
{
Status
:
apb
.
Status_STATUS_OK
,
Roles
:
[]
*
apb
.
Role
{
{
Name
:
"adminTestRole"
,
Description
:
"Admin"
,
Permissions
:
[]
string
{
"/gosdn.core.CoreService/GetPnd"
,
"/gosdn.core.CoreService/GetPndList"
,
}},
{
Name
:
"userTestRole"
,
Description
:
"User"
,
Permissions
:
[]
string
{
"/gosdn.pnd.PndService/GetChangeList"
,
}},
{
Name
:
randomRoleName
,
Description
:
"Not a role"
,
Permissions
:
[]
string
{
"nope"
,
},
},
},
},
wantLen
:
3
,
wantErr
:
false
,
},
}
for
_
,
tt
:=
range
tests
{
t
.
Run
(
tt
.
name
,
func
(
t
*
testing
.
T
)
{
got
,
err
:=
GetRoles
(
tt
.
args
.
ctx
,
tt
.
args
.
addr
)
if
(
err
!=
nil
)
!=
tt
.
wantErr
{
t
.
Errorf
(
"GetRoles() error = %v, wantErr %v"
,
err
,
tt
.
wantErr
)
return
}
if
got
!=
nil
&&
got
.
Status
==
tt
.
want
.
Status
{
if
len
(
got
.
Roles
)
!=
3
{
t
.
Errorf
(
"Role.GetRoles() = %v, want %v"
,
got
,
tt
.
want
)
}
for
_
,
gotR
:=
range
got
.
Roles
{
containsExpected
:=
false
for
_
,
wantR
:=
range
tt
.
want
.
Roles
{
gotPerm
:=
gotR
.
Permissions
wantPerm
:=
wantR
.
Permissions
if
gotR
.
Description
==
wantR
.
Description
&&
gotR
.
Name
==
wantR
.
Name
&&
reflect
.
DeepEqual
(
gotPerm
,
wantPerm
)
{
containsExpected
=
true
break
}
}
if
!
containsExpected
{
t
.
Errorf
(
"Role.GetRoles() = %v, want %v"
,
got
,
tt
.
want
)
}
}
}
})
}
}
func
TestUpdateRoles
(
t
*
testing
.
T
)
{
type
args
struct
{
ctx
context
.
Context
addr
string
roles
[]
*
apb
.
Role
}
tests
:=
[]
struct
{
name
string
args
args
want
*
apb
.
UpdateRolesResponse
wantErr
bool
}{
{
name
:
"default update roles"
,
args
:
args
{
ctx
:
context
.
TODO
(),
addr
:
testAPIEndpoint
,
roles
:
[]
*
apb
.
Role
{
{
Id
:
adminRoleID
,
Name
:
"New Name"
,
},
},
},
want
:
&
apb
.
UpdateRolesResponse
{
Status
:
apb
.
Status_STATUS_OK
,
},
wantErr
:
false
,
},
{
name
:
"error update roles"
,
args
:
args
{
ctx
:
context
.
TODO
(),
addr
:
testAPIEndpoint
,
roles
:
[]
*
apb
.
Role
{
{
Id
:
uuid
.
NewString
(),
Name
:
"New Name"
,
},
},
},
want
:
nil
,
wantErr
:
true
,
},
}
for
_
,
tt
:=
range
tests
{
t
.
Run
(
tt
.
name
,
func
(
t
*
testing
.
T
)
{
got
,
err
:=
UpdateRoles
(
tt
.
args
.
ctx
,
tt
.
args
.
addr
,
tt
.
args
.
roles
)
if
(
err
!=
nil
)
!=
tt
.
wantErr
{
t
.
Errorf
(
"UpdateRoles() error = %v, wantErr %v"
,
err
,
tt
.
wantErr
)
return
}
if
got
!=
nil
&&
got
.
Status
!=
tt
.
want
.
Status
{
t
.
Errorf
(
"Role.UpdateRoles() = %v, want %v"
,
got
,
tt
.
want
)
}
})
}
}
func
TestDeletePermissionForRole
(
t
*
testing
.
T
)
{
clearAndCreateAuthTestSetup
()
type
args
struct
{
ctx
context
.
Context
addr
string
name
string
permissionsToDelete
[]
string
}
tests
:=
[]
struct
{
name
string
args
args
want
*
apb
.
DeletePermissionsForRoleResponse
wantErr
bool
}{
{
name
:
"default delete permissions for role"
,
args
:
args
{
ctx
:
context
.
TODO
(),
addr
:
testAPIEndpoint
,
name
:
"adminTestRole"
,
permissionsToDelete
:
[]
string
{
"/gosdn.core.CoreService/GetPnd"
,
"/gosdn.core.CoreService/GetPndList"
,
},
},
want
:
&
apb
.
DeletePermissionsForRoleResponse
{
Status
:
apb
.
Status_STATUS_OK
,
},
wantErr
:
false
,
},
{
name
:
"error delete permissions for role"
,
args
:
args
{
ctx
:
context
.
TODO
(),
addr
:
testAPIEndpoint
,
name
:
"adminTestRole"
,
permissionsToDelete
:
[]
string
{
"foo"
,
},
},
want
:
nil
,
wantErr
:
true
,
},
}
for
_
,
tt
:=
range
tests
{
t
.
Run
(
tt
.
name
,
func
(
t
*
testing
.
T
)
{
got
,
err
:=
DeletePermissionForRole
(
tt
.
args
.
ctx
,
tt
.
args
.
addr
,
tt
.
args
.
name
,
tt
.
args
.
permissionsToDelete
)
if
(
err
!=
nil
)
!=
tt
.
wantErr
{
t
.
Errorf
(
"DeletePermissionForRole() error = %v, wantErr %v"
,
err
,
tt
.
wantErr
)
return
}
if
got
!=
nil
&&
got
.
Status
!=
tt
.
want
.
Status
{
t
.
Errorf
(
"Role.DeletePermissionsForRole() = %v, want %v"
,
got
,
tt
.
want
)
}
})
}
}
func
TestDeleteRoles
(
t
*
testing
.
T
)
{
type
args
struct
{
ctx
context
.
Context
addr
string
roleName
[]
string
}
tests
:=
[]
struct
{
name
string
args
args
want
*
apb
.
DeleteRolesResponse
wantErr
bool
}{
{
name
:
"default delete roles"
,
args
:
args
{
ctx
:
context
.
TODO
(),
addr
:
testAPIEndpoint
,
roleName
:
[]
string
{
"userTestRole"
,
"adminTestRole"
,
},
},
want
:
&
apb
.
DeleteRolesResponse
{
Status
:
apb
.
Status_STATUS_OK
,
},
wantErr
:
false
,
},
{
name
:
"error delete roles"
,
args
:
args
{
ctx
:
context
.
TODO
(),
addr
:
testAPIEndpoint
,
roleName
:
[]
string
{
"no"
,
},
},
want
:
nil
,
wantErr
:
true
,
},
}
for
_
,
tt
:=
range
tests
{
t
.
Run
(
tt
.
name
,
func
(
t
*
testing
.
T
)
{
clearAndCreateAuthTestSetup
()
got
,
err
:=
DeleteRoles
(
tt
.
args
.
ctx
,
tt
.
args
.
addr
,
tt
.
args
.
roleName
)
if
(
err
!=
nil
)
!=
tt
.
wantErr
{
t
.
Errorf
(
"DeleteRoles() error = %v, wantErr %v"
,
err
,
tt
.
wantErr
)
return
}
if
got
!=
nil
&&
got
.
Status
!=
tt
.
want
.
Status
{
t
.
Errorf
(
"Role.DeleteRoles() = %v, want %v"
,
got
,
tt
.
want
)
}
})
}
}
Loading