2018-08-16 12:36:27 +02:00
# -*- coding: utf-8 -*-
import base
import swagger_client
2018-11-14 09:23:44 +01:00
from swagger_client . rest import ApiException
2018-08-16 12:36:27 +02:00
2018-11-20 07:24:13 +01:00
def is_member_exist_in_project ( members , member_user_name , expected_member_role_id = None ) :
result = False
for member in members :
if member . entity_name == member_user_name :
if expected_member_role_id != None :
if member . role_id == expected_member_role_id :
return True
else :
return True
return result
2019-04-11 09:05:46 +02:00
def get_member_id_by_name ( members , member_user_name ) :
for member in members :
if member . entity_name == member_user_name :
return member . id
return None
2018-08-16 12:36:27 +02:00
class Project ( base . Base ) :
2018-11-14 09:23:44 +01:00
def create_project ( self , name = None , metadata = None , expect_status_code = 201 , expect_response_body = None , * * kwargs ) :
2018-09-19 11:49:43 +02:00
if name is None :
name = base . _random_name ( " project " )
2018-10-31 06:13:31 +01:00
if metadata is None :
metadata = { }
2018-08-16 12:36:27 +02:00
client = self . _get_client ( * * kwargs )
2018-11-14 09:23:44 +01:00
try :
_ , status_code , header = client . projects_post_with_http_info ( swagger_client . ProjectReq ( name , metadata ) )
except ApiException as e :
2018-11-29 11:27:53 +01:00
base . _assert_status_code ( expect_status_code , e . status )
if expect_response_body is not None :
base . _assert_status_body ( expect_response_body , e . body )
return
2018-11-14 09:23:44 +01:00
base . _assert_status_code ( expect_status_code , status_code )
2018-11-29 11:27:53 +01:00
base . _assert_status_code ( 201 , status_code )
2018-11-14 09:23:44 +01:00
return base . _get_id_from_header ( header ) , name
2018-10-31 06:13:31 +01:00
def get_projects ( self , params , * * kwargs ) :
client = self . _get_client ( * * kwargs )
data = [ ]
data , status_code , _ = client . projects_get_with_http_info ( * * params )
base . _assert_status_code ( 200 , status_code )
return data
2018-11-01 11:26:04 +01:00
def projects_should_exist ( self , params , expected_count = None , expected_project_id = None , * * kwargs ) :
project_data = self . get_projects ( params , * * kwargs )
actual_count = len ( project_data )
if expected_count is not None and actual_count != expected_count :
raise Exception ( r " Private project count should be {} . " . format ( expected_count ) )
if expected_project_id is not None and actual_count == 1 and str ( project_data [ 0 ] . project_id ) != str ( expected_project_id ) :
raise Exception ( r " Project-id check failed, expect {} but got {} , please check this test case. " . format ( str ( expected_project_id ) , str ( project_data [ 0 ] . project_id ) ) )
2018-10-31 06:13:31 +01:00
def check_project_name_exist ( self , name = None , * * kwargs ) :
client = self . _get_client ( * * kwargs )
_ , status_code , _ = client . projects_head_with_http_info ( name )
return {
200 : True ,
404 : False ,
} . get ( status_code , ' error ' )
2018-11-29 11:27:53 +01:00
def get_project ( self , project_id , expect_status_code = 200 , expect_response_body = None , * * kwargs ) :
2018-10-31 06:13:31 +01:00
client = self . _get_client ( * * kwargs )
2018-11-20 07:24:13 +01:00
try :
data , status_code , _ = client . projects_project_id_get_with_http_info ( project_id )
except ApiException as e :
2018-11-29 11:27:53 +01:00
base . _assert_status_code ( expect_status_code , e . status )
if expect_response_body is not None :
base . _assert_status_body ( expect_response_body , e . body )
return
2018-11-20 07:24:13 +01:00
base . _assert_status_code ( expect_status_code , status_code )
2018-11-29 11:27:53 +01:00
base . _assert_status_code ( 200 , status_code )
2018-10-31 06:13:31 +01:00
return data
2019-08-14 11:47:52 +02:00
def update_project ( self , project_id , expect_status_code = 200 , metadata = None , cve_whitelist = None , * * kwargs ) :
2018-10-31 06:13:31 +01:00
client = self . _get_client ( * * kwargs )
2019-08-14 11:47:52 +02:00
project = swagger_client . ProjectReq ( metadata = metadata , cve_whitelist = cve_whitelist )
try :
_ , sc , _ = client . projects_project_id_put_with_http_info ( project_id , project )
except ApiException as e :
base . _assert_status_code ( expect_status_code , e . status )
else :
base . _assert_status_code ( expect_status_code , sc )
2018-10-31 06:13:31 +01:00
2018-11-01 11:26:04 +01:00
def delete_project ( self , project_id , expect_status_code = 200 , * * kwargs ) :
2018-10-31 06:13:31 +01:00
client = self . _get_client ( * * kwargs )
_ , status_code , _ = client . projects_project_id_delete_with_http_info ( project_id )
2018-11-01 11:26:04 +01:00
base . _assert_status_code ( expect_status_code , status_code )
2018-10-31 06:13:31 +01:00
2018-11-29 11:27:53 +01:00
def get_project_log ( self , project_id , expect_status_code = 200 , * * kwargs ) :
client = self . _get_client ( * * kwargs )
body , status_code , _ = client . projects_project_id_logs_get_with_http_info ( project_id )
base . _assert_status_code ( expect_status_code , status_code )
return body
def filter_project_logs ( self , project_id , operator , repository , tag , operation_type , * * kwargs ) :
access_logs = self . get_project_log ( project_id , * * kwargs )
count = 0
for each_access_log in list ( access_logs ) :
if each_access_log . username == operator and \
each_access_log . repo_name . strip ( r ' / ' ) == repository and \
each_access_log . repo_tag == tag and \
each_access_log . operation == operation_type :
count = count + 1
return count
2018-10-31 06:13:31 +01:00
def get_project_members ( self , project_id , * * kwargs ) :
2018-11-20 07:24:13 +01:00
client = self . _get_client ( * * kwargs )
return client . projects_project_id_members_get ( project_id )
2018-11-29 11:27:53 +01:00
def get_project_member ( self , project_id , member_id , expect_status_code = 200 , expect_response_body = None , * * kwargs ) :
2018-10-31 06:13:31 +01:00
client = self . _get_client ( * * kwargs )
data = [ ]
2018-11-20 07:24:13 +01:00
try :
data , status_code , _ = client . projects_project_id_members_mid_get_with_http_info ( project_id , member_id , )
except ApiException as e :
2018-11-29 11:27:53 +01:00
base . _assert_status_code ( expect_status_code , e . status )
if expect_response_body is not None :
base . _assert_status_body ( expect_response_body , e . body )
return
2018-11-20 07:24:13 +01:00
base . _assert_status_code ( expect_status_code , status_code )
2018-11-29 11:27:53 +01:00
base . _assert_status_code ( 200 , status_code )
2018-11-20 07:24:13 +01:00
return data
2019-04-11 09:05:46 +02:00
def get_project_member_id ( self , project_id , member_user_name , * * kwargs ) :
members = self . get_project_members ( project_id , * * kwargs )
result = get_member_id_by_name ( list ( members ) , member_user_name )
if result == None :
raise Exception ( r " Failed to get member id of member {} in project {} . " . format ( member_user_name , project_id ) )
else :
return result
2018-11-20 07:24:13 +01:00
def check_project_member_not_exist ( self , project_id , member_user_name , * * kwargs ) :
members = self . get_project_members ( project_id , * * kwargs )
result = is_member_exist_in_project ( list ( members ) , member_user_name )
if result == True :
raise Exception ( r " User {} should not be a member of project with ID {} . " . format ( member_user_name , project_id ) )
def check_project_members_exist ( self , project_id , member_user_name , expected_member_role_id = None , * * kwargs ) :
members = self . get_project_members ( project_id , * * kwargs )
result = is_member_exist_in_project ( members , member_user_name , expected_member_role_id = expected_member_role_id )
if result == False :
raise Exception ( r " User {} should be a member of project with ID {} . " . format ( member_user_name , project_id ) )
def update_project_member_role ( self , project_id , member_id , member_role_id , expect_status_code = 200 , * * kwargs ) :
client = self . _get_client ( * * kwargs )
role = swagger_client . Role ( role_id = member_role_id )
data , status_code , _ = client . projects_project_id_members_mid_put_with_http_info ( project_id , member_id , role = role )
base . _assert_status_code ( expect_status_code , status_code )
2019-02-18 06:47:16 +01:00
base . _assert_status_code ( 200 , status_code )
2018-10-31 06:13:31 +01:00
return data
2018-11-20 07:24:13 +01:00
def delete_project_member ( self , project_id , member_id , expect_status_code = 200 , * * kwargs ) :
client = self . _get_client ( * * kwargs )
_ , status_code , _ = client . projects_project_id_members_mid_delete_with_http_info ( project_id , member_id )
base . _assert_status_code ( expect_status_code , status_code )
2019-02-18 06:47:16 +01:00
base . _assert_status_code ( 200 , status_code )
2018-11-20 07:24:13 +01:00
2018-11-01 11:26:04 +01:00
def add_project_members ( self , project_id , user_id , member_role_id = None , expect_status_code = 201 , * * kwargs ) :
2018-10-31 06:13:31 +01:00
if member_role_id is None :
member_role_id = 1
_member_user = { " user_id " : int ( user_id ) }
projectMember = swagger_client . ProjectMember ( member_role_id , member_user = _member_user )
client = self . _get_client ( * * kwargs )
data = [ ]
2018-11-20 07:24:13 +01:00
data , status_code , header = client . projects_project_id_members_post_with_http_info ( project_id , project_member = projectMember )
2019-02-18 06:47:16 +01:00
base . _assert_status_code ( expect_status_code , status_code )
2018-11-20 07:24:13 +01:00
return base . _get_id_from_header ( header )
2019-12-23 08:53:11 +01:00
def add_project_robot_account ( self , project_id , project_name , expires_at , robot_name = None , robot_desc = None , has_pull_right = True , has_push_right = True , expect_status_code = 201 , * * kwargs ) :
2019-02-18 06:47:16 +01:00
if robot_name is None :
robot_name = base . _random_name ( " robot " )
if robot_desc is None :
robot_desc = base . _random_name ( " robot_desc " )
if has_pull_right is False and has_push_right is False :
has_pull_right = True
access_list = [ ]
resource_by_project_id = " /project/ " + str ( project_id ) + " /repository "
action_pull = " pull "
action_push = " push "
if has_pull_right is True :
robotAccountAccess = swagger_client . RobotAccountAccess ( resource = resource_by_project_id , action = action_pull )
access_list . append ( robotAccountAccess )
if has_push_right is True :
robotAccountAccess = swagger_client . RobotAccountAccess ( resource = resource_by_project_id , action = action_push )
access_list . append ( robotAccountAccess )
2019-12-23 08:53:11 +01:00
robotAccountCreate = swagger_client . RobotAccountCreate ( robot_name , robot_desc , expires_at , access_list )
2019-02-18 06:47:16 +01:00
client = self . _get_client ( * * kwargs )
data = [ ]
data , status_code , header = client . projects_project_id_robots_post_with_http_info ( project_id , robotAccountCreate )
base . _assert_status_code ( expect_status_code , status_code )
base . _assert_status_code ( 201 , status_code )
return base . _get_id_from_header ( header ) , data
def get_project_robot_account_by_id ( self , project_id , robot_id , * * kwargs ) :
client = self . _get_client ( * * kwargs )
data , status_code , _ = client . projects_project_id_robots_robot_id_get_with_http_info ( project_id , robot_id )
return data
def disable_project_robot_account ( self , project_id , robot_id , disable , expect_status_code = 200 , * * kwargs ) :
client = self . _get_client ( * * kwargs )
robotAccountUpdate = swagger_client . RobotAccountUpdate ( disable )
_ , status_code , _ = client . projects_project_id_robots_robot_id_put_with_http_info ( project_id , robot_id , robotAccountUpdate )
base . _assert_status_code ( expect_status_code , status_code )
base . _assert_status_code ( 200 , status_code )
def delete_project_robot_account ( self , project_id , robot_id , expect_status_code = 200 , * * kwargs ) :
client = self . _get_client ( * * kwargs )
_ , status_code , _ = client . projects_project_id_robots_robot_id_delete_with_http_info ( project_id , robot_id )
base . _assert_status_code ( expect_status_code , status_code )
base . _assert_status_code ( 200 , status_code )