mirror of
https://github.com/goharbor/harbor.git
synced 2024-11-01 08:09:59 +01:00
5dca7fb867
Signed-off-by: danfengliu <danfengl@vmware.com>
59 lines
2.5 KiB
Python
59 lines
2.5 KiB
Python
from __future__ import absolute_import
|
|
|
|
import unittest
|
|
|
|
from testutils import ADMIN_CLIENT
|
|
from testutils import TEARDOWN
|
|
from library.user import User
|
|
from library.configurations import Configurations
|
|
|
|
class TestProjects(unittest.TestCase):
|
|
@classmethod
|
|
def setUp(self):
|
|
self.conf= Configurations()
|
|
self.user = User()
|
|
|
|
@classmethod
|
|
def tearDown(self):
|
|
print("Case completed")
|
|
|
|
@unittest.skipIf(TEARDOWN == False, "Test data won't be erased.")
|
|
def test_ClearData(self):
|
|
#1. Delete user(UA);
|
|
self.user.delete_user(TestProjects.user_assign_sys_admin_id, **ADMIN_CLIENT)
|
|
|
|
def testAssignSysAdmin(self):
|
|
"""
|
|
Test case:
|
|
Assign Sys Admin
|
|
Test step and expected result:
|
|
1. Create a new user(UA);
|
|
2. Set user(UA) has sysadmin role by admin, check user(UA) can modify system configuration;
|
|
3. 3. Set user(UA) has no sysadmin role by admin, check user(UA) can not modify system configuration;
|
|
4. Set user(UA) has sysadmin role by admin, check user(UA) can modify system configuration.
|
|
Tear down:
|
|
1. Delete user(UA).
|
|
"""
|
|
url = ADMIN_CLIENT["endpoint"]
|
|
user_assign_sys_admin_password = "Aa123456"
|
|
|
|
#1. Create a new user(UA);
|
|
TestProjects.user_assign_sys_admin_id, user_assign_sys_admin_name = self.user.create_user(user_password = user_assign_sys_admin_password, **ADMIN_CLIENT)
|
|
USER_ASSIGN_SYS_ADMIN_CLIENT=dict(endpoint = url, username = user_assign_sys_admin_name, password = user_assign_sys_admin_password)
|
|
|
|
#2. Set user(UA) has sysadmin role by admin, check user(UA) can modify system configuration;
|
|
self.user.update_user_role_as_sysadmin(TestProjects.user_assign_sys_admin_id, True, **ADMIN_CLIENT)
|
|
self.conf.set_configurations_of_token_expiration(60, **USER_ASSIGN_SYS_ADMIN_CLIENT)
|
|
|
|
#3. Set user(UA) has no sysadmin role by admin, check user(UA) can not modify system configuration;
|
|
self.user.update_user_role_as_sysadmin(TestProjects.user_assign_sys_admin_id, False, **ADMIN_CLIENT)
|
|
self.conf.set_configurations_of_token_expiration(70, expect_status_code = 403, **USER_ASSIGN_SYS_ADMIN_CLIENT)
|
|
|
|
#4. Set user(UA) has sysadmin role by admin, check user(UA) can modify system configuration.
|
|
self.user.update_user_role_as_sysadmin(TestProjects.user_assign_sys_admin_id, True, **ADMIN_CLIENT)
|
|
self.conf.set_configurations_of_token_expiration(80, **USER_ASSIGN_SYS_ADMIN_CLIENT)
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main()
|
|
|