class LinuxResource(object): def __init__(self, driver): self.driver = driver self.frameElem = frameElement(driver) self.resource = Resource(driver) self.account = Accountmgr(driver) u'''添加和编辑Linux资源 Parameters: - data:excel中的一行数据 ''' def add_edit_linux_resource(self, data): self.frameElem.from_frame_to_otherFrame("mainFrame") #资源名称 self.resource.set_resource_name(data[3]) #资源ip self.resource.set_resource_ip(data[4]) #归属部门 if data[5] != 'no': self.resource.set_depart(data[5]) self.resource.select_all_agreement() #从IP if data[6] != 'no': self.resource.set_resource_fortIps(data[6]) #系统版本 if data[7] != 'no': self.resource.set_sys_version(data[7]) #密码策略 if data[8] != 'no': self.resource.select_pwd_strategy(data[8]) #改密驱动名称 if data[9] != 'no': self.resource.set_changePwd_driver(data[9]) #管理员帐号 if data[10] != 'no': self.resource.click_account_sync() self.resource.set_admin_account(data[10]) #管理员口令 if data[11] != 'no': self.resource.set_admin_pwd(data[11]) #口令确认 if data[12] != 'no': self.resource.set_confirm_pwd(data[12]) self.resource.click_up_super() #提权账号口令 self.resource.set_super_pwd(data[13]) #确认口令 self.resource.set_super_confirm_pwd(data[14]) self.resource.resoure_save_button() u'''校验Linux资源 Parameters: - datarow:excel数据位于第几行 - data:excel中的一行数据 ''' def check_linux_resource(self, datarow, data): self.frameElem.from_frame_to_otherFrame("mainFrame") #资源名称 self.resource.set_resource_name(data[2]) #资源ip self.resource.set_resource_ip(data[3]) #协议类型 if data[4] != 'no': self.resource.select_agreement(data[4]) #协议类型 端口 if datarow == 7: self.resource.set_port(data[4], data[5]) if datarow == 8: self.resource.clear_port("Ssh1") if datarow == 9: self.resource.set_port("Ssh1", data[5]) if datarow == 12: self.resource.click_account_sync() self.resource.click_up_super() if datarow == 13: #提权账号口令 if data[6] != 'no': self.resource.set_super_pwd(data[6]) #确认口令 if data[7] != 'no': self.resource.set_super_confirm_pwd(data[7]) self.resource.set_super_prompt() self.resource.resoure_save_button() u'''添加资源账号 Parameters: - editacttname:编辑的资源账号名称 - value:选择编辑方式的value值 - addactname:填写的资源账号名称 - pwd:账号口令 - cmfpwd:确认口令 ''' def add_edit_resource_account(self, editacttname='no', value='no', addactname='no', pwd='no', cmfpwd='no'): self.account.click_account_add_edit_button(editacttname) if value != 'no': self.account.select_edit_way(value) if addactname != 'no': self.account.set_account_name(addactname) if pwd != 'no': self.account.set_account_pwd(pwd) if cmfpwd != 'no': self.account.set_account_confirm_pwd(cmfpwd) self.account.set_authorize() self.account.click_save_account() u'''校验资源账号 Parameters: - value:选择编辑方式的value值 - addactname:填写的资源账号名称 - pwd:账号口令 - cmfpwd:确认口令 ''' def check_resource_account(self, value='no', addactname='no', pwd='no', cmfpwd='no'): if addactname == 'no': self.account.clear_account_name() if pwd == 'no': self.account.clear_account_pwd() if cmfpwd == 'no': self.account.clear_account_confirm_pwd() if value != 'no': self.account.select_edit_way(value) if addactname != 'no': self.account.set_account_name(addactname) if pwd != 'no': self.account.set_account_pwd(pwd) if cmfpwd != 'no': self.account.set_account_confirm_pwd(cmfpwd) self.account.set_authorize() self.account.click_save_account()
class CommonSuiteData(): def __init__(self, driver): self.driver = driver self.dataFile = dataFileName() self.cmf = commonFun(self.driver) self.initDriver = initDriver() self.loginElem = loginPage(self.driver) self.roleElem = Role(self.driver) self.userElem = UserPage(self.driver) self.frameElem = frameElement(self.driver) self.authElem = AuthMethodPage(self.driver) self.dptment = Department(self.driver) self.resource = Resource(self.driver) self.account = Accountmgr(self.driver) self.windowsElem = WindowsResource(self.driver) self.databaseElem = DatabaseResource(self.driver) self.usergroup = Usergroup(self.driver) self.regroup = Regroup(self.driver) self.appElem = AppPage(self.driver) self.authorizationElem = AuthorizationPage(self.driver) self.testAutho = testAuthorization(self.driver) self.clientElem = ClientPage(self.driver) self.command = CommandRule(self.driver) self.ntp = NtpService(self.driver) self.mail = MailPage(self.driver) self.syslog = Syslog(driver) self.ssoElem = SsoPage(self.driver) self.alarm = AlarmPage(self.driver) self.PwdStr = PwdStrategy(self.driver) self.passwdenvelope = EnvelopePage(self.driver) u'''切换模块 parameter: levelText1 : 一级模块名称 levelText2 : 二级模块名称 ''' def switch_to_moudle(self, levelText1, levelText2): time.sleep(2) self.frameElem.from_frame_to_otherFrame("topFrame") self.cmf.select_menu(levelText1) self.cmf.select_menu(levelText1, levelText2) #----------------------------------------用户相关------------------------------ u'''填写用户信息 parameters: data[1] : 用户名称 data[3] : 用户账号 data[4] : 用户密码 data[5] : 确认密码 data[6] : 开始时间 data[7] : 访问方式 data[8] : AD域账号 roleText : 用户角色 ''' def set_user_basic_info(self, data, roleText, status='no'): self.frameElem.from_frame_to_otherFrame("mainFrame") if status != 'no': self.userElem.add_role_button() else: self.userElem.add_button() self.userElem.set_user_account(data[3]) self.userElem.set_user_name(data[1]) self.userElem.set_user_pwd(data[4]) self.userElem.set_user_enquire_pwd(data[5]) self.userElem.set_start_time(data[6]) if data[12] != "": self.userElem.set_user_email(data[12]) if data[10] != "": self.userElem.set_dep(data[10]) if data[7] != "": #设置访问方式 self.userElem.click_advanced_option() self.userElem.set_auth_method_rule(data[7]) #访问方式不是默认方式 if int(data[7]) != 2: self.userElem.set_ad_name(data[8]) if data[9] != "": self.userElem.set_user_role(roleText) self.userElem.click_role_add_button() self.userElem.save_button() self.cmf.click_login_msg_button() u'''删除用户''' def del_user(self): self.switch_to_moudle(u"运维管理", u"用户") self.frameElem.from_frame_to_otherFrame("mainFrame") self.userElem.select_all_button() self.userElem.del_button() self.frameElem.switch_to_content() self.cmf.click_login_msg_button() self.cmf.click_login_msg_button() u'''用户退出''' def user_quit(self): self.loginElem.quit() #-----------------------------部门-------------------------------------------- u'''填写部门名称 parameters : data[0] : 部门名称 data[1] : 操作类型(添加:0) data[2] : 添加的部门名称 ''' def set_dep(self, data): self.switch_to_moudle(u"运维管理", u"组织定义") self.dptment.click_left_department() #点击展开按钮 self.dptment.click_dept_switch() self.dptment.click_basic_operation(data[0], int(data[1])) self.dptment.popup_sendkey(data[2]) self.dptment.click_ok_button() self.cmf.click_login_msg_button() def set_del_dep(self, data): self.switch_to_moudle(u"运维管理", u"组织定义") self.dptment.click_left_department() self.dptment.click_dept_switch() self.dptment.click_basic_operation(data[0], int(data[1])) self.cmf.click_login_msg_button() self.cmf.click_login_msg_button() #-----------------------------用户组------------------------------------------ u'''添加用户到用户组''' def set_user_to_group(self, data): # self.usergroup.click_left_usergroup() # self.usergroup.click_usergroup_switch() self.usergroup.click_usergroup_add_user(data[3], data[4]) self.regroup.check_depart(data[5]) self.usergroup.click_usergroup_add_user_query() self.regroup.check_all_resource() self.regroup.click_resource_okbutton() self.cmf.click_login_msg_button() u'''填写用户组信息 parameters: data[0] : 操作类型(添加:0) data[1] : 部门名称 data[2] : 编辑的用户组名称 data[3] : 添加的用户组名称 ''' def set_add_user_group(self, data): self.switch_to_moudle(u"运维管理", u"组织定义") self.usergroup.click_left_usergroup() self.usergroup.click_usergroup_switch() self.usergroup.usergroup_click_basic_operation(int(data[0]), data[1], data[2]) self.dptment.popup_sendkey(data[3]) self.dptment.click_ok_button() self.cmf.click_login_msg_button() if data[4] != "": self.set_user_to_group(data) u'''删除用户组 parameters : data[0] : 操作类型(删除:4) data[1] : 部门名称 data[2] : 删除的用户组名称 ''' def set_del_user_group(self, data): self.switch_to_moudle(u"运维管理", u"组织定义") self.usergroup.click_left_usergroup() self.usergroup.click_usergroup_switch() self.usergroup.usergroup_click_basic_operation(int(data[0]), data[1], data[2]) self.cmf.click_login_msg_button() self.cmf.click_login_msg_button() #-----------------------------资源组------------------------------------------ u'''添加资源到资源组''' def set_res_to_group(self, data): self.regroup.click_regroup_add_resouce(data[3], data[4]) self.regroup.check_depart(data[5]) self.regroup.click_regroup_add_resouce_query() self.regroup.check_all_resource() self.regroup.click_resource_okbutton() time.sleep(1) self.cmf.click_login_msg_button() u'''填写资源组信息 parameters: data[0] : 操作类型(添加:0) data[1] : 部门名称 data[2] : 编辑的资源组名称 data[3] : 添加的资源组名称 ''' def set_add_res_group(self, data): self.switch_to_moudle(u"运维管理", u"组织定义") self.regroup.click_left_regroup() self.regroup.click_regroup_switch() self.regroup.regroup_click_basic_operation(int(data[0]), data[1], data[2]) self.dptment.popup_sendkey(data[3]) self.dptment.click_ok_button() self.cmf.click_login_msg_button() if data[4] != "": self.set_res_to_group(data) u'''删除资源组 parameters : data[0] : 操作类型(删除:4) data[1] : 部门名称 data[2] : 删除的资源组名称 ''' def set_del_res_group(self, data): self.switch_to_moudle(u"运维管理", u"组织定义") self.regroup.click_left_regroup() self.regroup.click_regroup_switch() self.regroup.regroup_click_basic_operation(int(data[0]), data[1], data[2]) self.cmf.click_login_msg_button() self.cmf.click_login_msg_button() #-----------------------------资源-------------------------------------------- u'''填写资源基本信息 parameters : data[0]:资源类型 data[1]:资源名称 data[2]:资源IP data[3]:部门 ''' def set_resource_info(self, data): self.switch_to_moudle(u"运维管理", u"资源") self.frameElem.from_frame_to_otherFrame("mainFrame") self.resource.click_add_edit_button() self.resource.select_resource_type(data[0]) self.resource.set_resource_name(data[1]) self.resource.set_resource_ip(data[2]) if data[3] != 'no': time.sleep(5) self.resource.set_depart(data[3]) #选择协议 if data[4] != "": self.resource.select_agreement(data[4]) if data[5] != "": self.resource.click_account_sync() self.resource.set_admin_account(data[5]) self.resource.set_admin_pwd(data[6]) self.resource.set_confirm_pwd(data[7]) #提权口令 if data[8] != "": self.resource.click_up_super() self.resource.set_super_pwd(data[8]) self.resource.set_super_confirm_pwd(data[9]) #填写域名 if data[10] != "": self.databaseElem.set_domain_name(data[10]) #账号分类 if data[11] != "": self.resource.click_account_sync() self.windowsElem.select_account_type(data[11]) #归属域控主机 if data[12] != "": self.windowsElem.select_attach_domian(data[12]) #主机名 if data[13] != "": self.databaseElem.set_host_name(data[13]) self.resource.click_save_button() self.cmf.click_login_msg_button() time.sleep(3) # self.driver.implicitly_wait(3) self.cmf.back() u'''填写数据库基本信息''' def set_database_res_info(self, data): self.switch_to_moudle(u"运维管理", u"资源") self.frameElem.from_frame_to_otherFrame("mainFrame") self.resource.click_add_edit_button() self.resource.select_resource_type(data[2]) self.databaseElem.add_edit_database_resource(data) self.cmf.click_login_msg_button() time.sleep(3) self.cmf.back() u'''填写资源账号基本信息 parameters: data[1]:资源名称 data[4] : 账号编辑方式 data[5] : 账号名称 data[6] : 口令 data[7] : 确认口令 ''' def set_res_account(self, data): self.switch_to_moudle(u"运维管理", u"资源") self.account.click_account_manage_button(data[0]) time.sleep(1) self.account.click_account_add_edit_button(data[2]) self.account.select_edit_way(data[1]) if data[2] != "no": self.account.set_account_name(data[2]) self.account.set_account_pwd(data[3]) self.account.set_account_confirm_pwd(data[4]) self.account.set_authorize() self.account.click_save_account() self.cmf.click_login_msg_button() #-----------------------------授权---------------------------------------- u'''填写授权基本信息 parameters: data[1]:授权名称 data[2]:部门名称 data[3]:状态 ''' def set_authorization(self, data): self.switch_to_moudle(u'运维管理', u'授权') self.authorizationElem.add_button() self.authorizationElem.set_auth_name(data[1]) self.authorizationElem.set_dep(data[2], data[3]) self.authorizationElem.click_add_user() self.authorizationElem.set_select_user_search_button() self.authorizationElem.set_user_check_all_button() self.authorizationElem.set_ok_button() #添加资源 self.authorizationElem.click_add_res() self.authorizationElem.set_select_res_search_button() self.authorizationElem.set_res_check_all_button() self.authorizationElem.set_ok_button() self.authorizationElem.save_button() self.cmf.click_login_msg_button() self.cmf.back() #---------------------------------填写应用发布信息---------------------------- u'''填写应用发布信息''' def set_application_info(self, data): self.switch_to_moudle(u"系统配置", u"关联服务") self.appElem.app_module_button() self.appElem.click_add_button() self.appElem.set_name(data[0]) self.appElem.set_ip(data[1]) self.appElem.set_app_account(data[3]) self.appElem.set_pwd(data[4]) self.appElem.set_repwd(data[5]) self.appElem.ip_is_succ() self.appElem.click_save_button() self.cmf.click_login_msg_button() u'''删除应用发布''' def del_application(self, rowList): self.switch_to_moudle(u"系统配置", u"关联服务") self.appElem.app_module_button() self.frameElem.from_frame_to_otherFrame("rigthFrame") app_data = self.get_table_data("add_application") for dataRow in rowList: data = app_data[dataRow] if dataRow != 0: self.appElem.operate_del(data[0]) self.cmf.click_login_msg_button() self.cmf.click_login_msg_button() #-------------------------------------客户端----------------------------------- u'''填写客户端基本信息''' def set_client_info(self, data): #self.switch_to_moudle(u"系统配置",u"客户端配置") self.frameElem.from_frame_to_otherFrame("mainFrame") self.clientElem.add_button() self.clientElem.set_client_name(data[2]) self.clientElem.set_action_stream(data[3]) self.clientElem.set_database_res_type(data[0], data[1]) self.clientElem.save_button() u'''删除客户端''' def set_delete_client_info(self, data): #self.switch_to_moudle(u"系统配置",u"客户端配置") self.frameElem.from_frame_to_otherFrame("mainFrame") self.clientElem.select_query_res_type(data[0], data[1]) self.clientElem.click_query_button() self.clientElem.del_operation(data[2]) self.cmf.click_login_msg_button() #------------------------------资源账号授权------------------------------------ u'''添加用户和资源账号类型的授权''' def set_authorization_info(self, data): self.switch_to_moudle(u"运维管理", u"授权") self.testAutho.common_part(data) self.testAutho.add_user(data) self.authorizationElem.click_add_res_account() self.authorizationElem.set_select_res_ip(data[6]) self.authorizationElem.set_select_res_account(data[8]) self.authorizationElem.set_select_res_search_button() self.authorizationElem.set_res_check_all_button() self.authorizationElem.set_ok_button() self.authorizationElem.res_account_status() self.authorizationElem.save_button() self.cmf.click_login_msg_button() u'''删除授权''' def del_authorization(self): self.switch_to_moudle(u"运维管理", u"授权") self.frameElem.from_frame_to_otherFrame("mainFrame") self.authorizationElem.check_all() self.authorizationElem.del_button() self.cmf.click_login_msg_button() self.cmf.click_login_msg_button() #-----------------------------数据---------------------------------------- u'''获取数据 Parameters: - sheetname:sheet名称 return:表格数据 ''' def get_table_data(self, sheetname): filePath = self.dataFile.get_common_suite_test_data_url() fileData = self.dataFile.get_data(filePath, sheetname) return fileData u'''添加应用发布''' def add_application(self, rowList): app_data = self.get_table_data('add_application') for dataRow in rowList: data = app_data[dataRow] if dataRow != 0: self.set_application_info(data) u'''初始化用户登录''' def isomper_login(self): login_data = self.get_table_data('add_user') logindata = login_data[4] self.loginElem.login(logindata) u'''添加用户数据模板''' def add_user_data_module(self, rowList): self.switch_to_moudle(u"运维管理", u"用户") user_data = self.get_table_data("add_user") for dataRow in rowList: data = user_data[dataRow] if dataRow != 0: self.set_user_basic_info(data, data[9], data[13]) self.userElem.click_back_button() u'''添加系统管理员和部门管理员的用户''' def add_user_with_role(self): rowList = [1] self.add_user_data_module(rowList) u'''登录并切换至角色公用方法 parameters: login_status :'no'(登录状态:没有登录) ''' def login_and_switch_to_common(self, login_status='no'): login_data = self.get_table_data("add_user") logindata = login_data[1] if login_status == 'no': self.loginElem.login(logindata) #获取角色 roleList = logindata[9].split(',') return roleList u'''使用系统管理员登录系统''' def login_sysadmin(self): login_data = self.get_table_data('add_user') logindata = login_data[1] self.loginElem.login(logindata) u'''使用安全保密管理员登录系统''' def login_secadmin(self): login_data = self.get_table_data('add_user') logindata = login_data[2] self.loginElem.login(logindata) u'''使用安全审计员登录系统''' def login_sysaudit(self): login_data = self.get_table_data('add_user') logindata = login_data[3] self.loginElem.login(logindata) u'''用户登录系统''' def login_user(self, row): login_data = self.get_table_data('add_user') logindata = login_data[int(row)] self.loginElem.login(logindata) u'''切换至运维操作员''' def switch_to_operation(self): self.cmf.select_role_by_text(u"运维操作员") #使用新添加的用户登录 def use_new_user_login(self): login_data = self.get_table_data("add_user") logindata = login_data[1] time.sleep(2) self.loginElem.login(logindata) u'''运维管理员登录''' def sso_user_login(self, rowList): login_data = self.get_table_data("add_user") logindata = login_data[rowList] time.sleep(1) self.loginElem.login(logindata) u'''运维管理员AD域方式登录''' def sso_user_ad_login(self, rowList): login_data = self.get_table_data("add_user") logindata = login_data[rowList] self.frameElem.switch_to_content() self.loginElem.set_login_method(logindata[2]) self.loginElem.set_ad_login_username(logindata[3]) self.loginElem.set_ad_login_pwd(logindata[11]) time.sleep(1) self.loginElem.click_login_button() u'''添加认证配置''' def add_meth_method(self): meth_data = self.get_table_data("meth_method") methData = meth_data[1] self.switch_to_moudle(u"策略配置", u"认证强度") self.authElem.select_all_auth(methData) u'''会话配置,设置最大登录数''' def set_login_max_num(self): self.loginElem.set_max_login_count() u'''添加登录测试数据''' def add_login_data(self): rowList = [2, 3, 4, 5, 6, 7] self.add_user_data_module(rowList) u'''添加授权用户''' def add_authorization_user(self): rowList = [8, 9, 10, 11, 12] self.add_user_data_module(rowList) u'''添加应用发布用户''' def add_app_user(self): rowList = [3] self.add_user_data_module(rowList) u'''添加单点登录用户''' def add_sso_user(self): rowList = [6, 8, 9, 10, 11, 13] self.add_user_data_module(rowList) u'''添加部门''' def add_dep(self, rowList): dep_data = self.get_table_data("add_dep") for dataRow in rowList: data = dep_data[dataRow] if dataRow != 0: self.set_dep(data) u'''删除部门''' def del_dep(self, rowList): dep_data = self.get_table_data("del_dep") for dataRow in rowList: data = dep_data[dataRow] if dataRow != 0: self.set_del_dep(data) u'''增加资源数据模板''' def add_resource_modele(self, rowList): res_data = self.get_table_data("add_res") for dataRow in rowList: data = res_data[dataRow] if dataRow != 0: self.set_resource_info(data) u'''添加授权资源''' def add_resource(self): rowList = [1, 2] self.add_resource_modele(rowList) u'''添加sso资源''' def add_sso_resource(self): #rowList = [1,2,3,4,5,7,8] rowList = [1, 3, 4, 5] self.add_resource_modele(rowList) u'''添加依附操作系统''' def add_database_resource(self): rowList = [2] self.add_resource_modele(rowList) u'''添加资源账号数据模板''' def add_res_account_module(self, rowList): account_data = self.get_table_data("res_account") for dataRow in rowList: data = account_data[dataRow] if dataRow != 0: self.set_res_account(data) u'''添加授权资源账号''' def add_res_account(self): rowList = [1, 3] self.add_res_account_module(rowList) u'''添加sso资源账号''' def add_sso_res_account(self): rowList = [1, 2, 4, 5, 6, 7] #rowList = [1,2,3,4,5,6,7,9,10] self.add_res_account_module(rowList) u'''添加用户组''' def add_user_group(self, rowList): user_group_data = self.get_table_data("add_user_group") for dataRow in rowList: data = user_group_data[dataRow] if dataRow != 0: self.set_add_user_group(data) u'''删除用户组''' def del_user_group(self, rowList): user_group_data = self.get_table_data("del_user_group") for dataRow in rowList: data = user_group_data[dataRow] if dataRow != 0: self.set_del_user_group(data) u'''添加资源组''' def add_res_group(self, rowList): res_group_data = self.get_table_data("add_res_group") for dataRow in rowList: data = res_group_data[dataRow] if dataRow != 0: self.set_add_res_group(data) u'''删除资源组''' def del_res_group(self, rowList): res_group_data = self.get_table_data("del_res_group") for dataRow in rowList: data = res_group_data[dataRow] if dataRow != 0: self.set_del_res_group(data) u'''添加授权''' def add_authrization(self, rowList): auth_data = self.get_table_data("add_authorization") for dataRow in rowList: data = auth_data[dataRow] if dataRow != 0: self.set_authorization(data) u'''添加授权数据模板''' def add_authorization_module(self, rowList): autho_data = self.get_table_data("add_account_auth") for dataRow in rowList: data = autho_data[dataRow] if dataRow != 0: self.set_authorization_info(data) self.authorizationElem.back_button() u'''添加单点登录授权''' def add_sso_authorization(self): rowList = [1] #rowList = [1,2,3,4,5,6,7] self.add_authorization_module(rowList) u'''单点登录模板''' def sso_module(self, rowList): sso_data = self.get_table_data("sso") for dataRow in rowList: data = sso_data[dataRow] if dataRow != 0: self.frameElem.from_frame_to_otherFrame("rigthFrame") self.ssoElem.select_account(data[0], data[1]) self.ssoElem.select_sso_icon(data[0], data[2]) if data[3] != "": self.ssoElem.select_protocol(data[3]) #self.ssoElem.execute_chrome_key() self.ssoElem.choice_browser(data[2], data[4], data[5], data[6]) u'''添加客户端数据模板''' def add_client_module(self, rowList): client_data = self.get_table_data("add_client") self.switch_to_moudle(u"系统配置", u"客户端配置") for dataRow in rowList: data = client_data[dataRow] if dataRow != 0: self.set_client_info(data) u'''删除客户端数据模板''' def del_client_module(self, rowList): client_data = self.get_table_data("del_client") self.switch_to_moudle(u"系统配置", u"客户端配置") for dataRow in rowList: data = client_data[dataRow] if dataRow != 0: self.set_delete_client_info(data) u'''添加数据库资源模板''' def add_database_res_module(self, rowList): database_data = self.get_table_data("add_database") for dataRow in rowList: data = database_data[dataRow] if dataRow != 0: self.set_database_res_info(data) u'''删除用户数据模板''' def del_user_data_module(self, rowList): self.switch_to_moudle(u"运维管理", u"用户") self.frameElem.from_frame_to_otherFrame("mainFrame") user_data = self.get_table_data("add_user") for dataRow in rowList: data = user_data[dataRow] if dataRow != 0: self.switch_to_moudle(u"运维管理", u"用户") self.userElem.operate_delete(data[1]) self.frameElem.switch_to_content() self.cmf.click_login_msg_button() self.cmf.click_login_msg_button() u'''添加密码策略数据模板''' def add_strategy_data_module(self, rowList): self.switch_to_moudle(u"策略配置", u"密码策略") self.frameElem.from_frame_to_otherFrame("mainFrame") pwd_data = self.get_table_data("add_strategy") for dataRow in rowList: data = pwd_data[dataRow] if dataRow != 0: self.PwdStr.add_pwd_button() self.PwdStr.set_pwd_name(data[1]) self.PwdStr.term_of_validity(data[2]) self.PwdStr.password_length_min(data[3]) self.PwdStr.password_length_max(data[4]) self.PwdStr.set_lower_case(data[5]) self.PwdStr.set_capital(data[6]) self.PwdStr.set_minimum_digital(data[7]) self.PwdStr.set_Minimum_symbol(data[8]) self.PwdStr.save_button() self.frameElem.switch_to_content() self.cmf.click_msg_button(1) self.PwdStr.return_button() u'''删除密码策略数据模板''' def del_strategy_data_module(self, rowList): self.switch_to_moudle(u"策略配置", u"密码策略") self.frameElem.from_frame_to_otherFrame("mainFrame") pwd_data = self.get_table_data("add_strategy") for dataRow in rowList: data = pwd_data[dataRow] if dataRow != 0: self.PwdStr.del_sing_strategy(data[1]) self.frameElem.switch_to_content() self.cmf.click_login_msg_button() self.cmf.click_login_msg_button() u'''删除资源数据模板''' def del_resource_modele(self, rowList): self.switch_to_moudle(u"运维管理", u"资源") self.frameElem.from_frame_to_otherFrame("mainFrame") res_data = self.get_table_data("add_res") for dataRow in rowList: data = res_data[dataRow] if dataRow != 0: self.resource.click_del_button(data[1]) self.frameElem.switch_to_content() self.cmf.click_login_msg_button() self.cmf.click_login_msg_button() u'''删除授权数据模板''' def del_authorization_module(self, rowList): self.switch_to_moudle(u'运维管理', u'授权') self.frameElem.from_frame_to_otherFrame("mainFrame") autho_data = self.get_table_data("add_account_auth") for dataRow in rowList: data = autho_data[dataRow] if dataRow != 0: self.authorizationElem.click_auth_checkbox(data[2]) self.authorizationElem.del_button() self.frameElem.switch_to_content() self.cmf.click_login_msg_button() self.cmf.click_login_msg_button() #-------------------------------添加涉密版用户前置条件--------------------------------------- u'''前置条件通用''' def secret_user_prefix_condition(self): self.isomper_login() self.switch_to_moudle(u'角色管理', u'角色定义') #------------------------------部门前置条件----------------------------------- def depart_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() #切换到组织定义 self.switch_to_moudle(u"运维管理", u"组织定义") #------------------------------资源组前置条件----------------------------------- def regroup_module_prefix_condition(self): #使用安全保密管理员登录 self.login_secadmin() #添加资源 self.add_resource_modele([9, 6]) self.user_quit() #使用系统管理员登录 self.login_sysadmin() #切换到组织定义 self.switch_to_moudle(u"运维管理", u"组织定义") def regroup_module_post_condition(self): self.user_quit() #使用安全保密管理员登录 self.login_secadmin() #删除资源 self.del_resource_modele([9, 6]) self.user_quit() #------------------------------用户组前置条件----------------------------------- def usergroup_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() #添加用户 self.add_user_data_module([5, 6, 7, 8]) #切换到组织定义 self.switch_to_moudle(u"运维管理", u"组织定义") def usergroup_module_post_condition(self): self.del_user_data_module([5, 6, 7, 8]) self.user_quit() #------------------------------NTP服务前置条件--------------------------------- def ntp_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() #切换到NTP服务 self.switch_to_moudle(u'系统配置', u'关联服务') self.ntp.click_left_moudle(0) #-------------------------------SYSLOG前置条件--------------------------------- def syslog_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() #切换到NTP服务 self.switch_to_moudle(u'系统配置', u'关联服务') self.ntp.click_left_moudle(1) #------------------------------邮件前置条件--------------------------------- def mail_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() #切换到邮件服务 self.switch_to_moudle(u'系统配置', u'关联服务') self.mail.click_left_moudle_test() #------------------------------密码信封前置条件--------------------------------- def passwd_envelope_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() #切换到邮件服务 self.switch_to_moudle(u'系统配置', u'关联服务') self.passwdenvelope.click_left_moudle_envelope() #-------------------------------应用发布后置条件------------------------------- def application_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() self.add_user_data_module([9, 10]) self.switch_to_moudle(u"系统配置", u"关联服务") def application_module_post_condition(self): self.del_user_data_module([9, 10]) self.user_quit() #-------------------------------网卡配置前置条件------------------------------- def network_card_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() #切换到网卡配置 self.switch_to_moudle(u'系统配置', u'网络配置') #-------------------------------路由配置前置条件------------------------------- def routing_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() #切换到路由配置 self.cmf.select_menu(u'系统配置', u'网络配置', u'路由配置') #------------------------------备份还原前置条件----------------------------------- def backup_restore_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() #-----------------------------客户端配置前置条件------------------------------ def client_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() self.switch_to_moudle(u"系统配置", u"客户端配置") #-----------------------------AD域抽取前置条件------------------------------ def ad_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() self.add_user_data_module([18]) self.switch_to_moudle(u"系统配置", u"AD定时抽取") u'''AD域抽取后置条件''' def ad_module_post_condition(self): self.del_user_data_module([18]) self.user_quit() #------------------------------使用授权前置条件--------------------------------- def use_auth_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() self.switch_to_moudle(u'系统配置', u'使用授权') #------------------------------用户模块前置条件-------------------------------- u'''用户模块前置条件''' def user_module_prefix_condition(self): #使用系统管理员登录 self.login_sysadmin() self.switch_to_moudle(u'运维管理', u'用户') #--------------------------认证方式前置条件------------------------------------ u'''认证方式前置条件''' def auth_method_prefix_condition(self): #使用安全保密管理员登录 self.login_secadmin() self.add_user_data_module([11]) self.switch_to_moudle(u"策略配置", u"认证强度") self.frameElem.from_frame_to_otherFrame("mainFrame") u'''认证方式后置条件''' def auth_method_post_condition(self): self.del_user_data_module([11]) self.user_quit() #---------------------------------登录模块前置条件----------------------------- u'''登录模块前置条件''' def login_module_prefix_condition(self): #使用安全保密管理员登录 self.login_secadmin() #配置认证方式 self.add_meth_method() #配置最大登录数 self.set_login_max_num() #添加登录用户数据 self.add_user_data_module([12, 13, 14, 15, 16, 17]) #改变a的状态为关 self.userElem.change_user_status_off("gyrlogin2") #系统管理员退出 self.user_quit() u'''登录模块后置条件''' def login_module_post_condition(self): #使用安全保密管理员登录 self.login_secadmin() #删除认证方式 self.authElem.del_auth_method() self.del_user_data_module([12, 13, 14, 15, 16, 17]) self.user_quit() #------------------------------告警策略前置条件--------------------------------- def alarm_strategy_module_prefix_condition(self): #使用安全保密管理员登录 self.login_secadmin() def alarm_strategy_module_post_condition(self): self.alarm.del_command_config() self.alarm.del_default_config() self.alarm.del_auth_config() self.user_quit() #------------------------------会话配置前置条件-------------------------------- def session_module_prefix_condition(self): #使用安全保密管理员登录 self.login_secadmin() self.switch_to_moudle(u"策略配置", u"会话配置") #------------------------------密码策略前置条件-------------------------------- def pwdstr_module_prefix_condition(self): #使用安全保密管理员登录 self.login_secadmin() #添加资源 self.add_resource_modele([14]) self.add_user_data_module([19]) self.switch_to_moudle(u"策略配置", u"密码策略") def pwdstr_module_post_condition(self): self.del_resource_modele([14]) self.del_user_data_module([19]) self.user_quit() #------------------------------linux资源前置条件----------------------------------- def linuxre_module_prefix_condition(self): #使用安全保密管理员登录 self.login_secadmin() #添加密码策略 self.add_strategy_data_module([1]) #切换到资源 self.switch_to_moudle(u"运维管理", u"资源") def linuxre_module_post_condition(self): #删除密码策略 self.del_strategy_data_module([1]) self.user_quit() #------------------------------network资源前置条件----------------------------------- def networkre_module_prefix_condition(self): #使用安全保密管理员登录 self.login_secadmin() #切换到资源 self.switch_to_moudle(u"运维管理", u"资源") #------------------------------windows资源前置条件----------------------------------- def windowre_module_prefix_condition(self): #使用安全保密管理员登录 self.login_secadmin() #添加密码策略 self.add_strategy_data_module([2]) #切换到资源 self.switch_to_moudle(u"运维管理", u"资源") def windowre_module_post_condition(self): #删除密码策略 self.del_strategy_data_module([2]) self.user_quit() #-----------------------------数据库前置条件---------------------------------- def database_resource_prefix_condition(self): self.login_sysadmin() #添加应用发布 self.add_application([1]) self.user_quit() #使用安全保密管理员登录 self.login_secadmin() self.add_resource_modele([17]) self.switch_to_moudle(u"运维管理", u"资源") def database_resource_post_condition(self): self.del_resource_modele([17]) self.user_quit() self.login_sysadmin() self.del_application([1]) self.user_quit() #------------------------------授权前置条件----------------------------------- def authori_module_prefix_condition(self): #使用安全保密管理员登录 self.login_secadmin() self.add_resource_modele([15, 16]) self.add_res_account_module([18, 19]) self.user_quit() self.login_sysadmin() #添加授权用户 self.add_user_data_module([20, 21, 22, 23, 24]) self.add_res_group([1]) self.add_user_group([1]) self.user_quit() self.login_secadmin() self.switch_to_moudle(u'运维管理', u'授权') def authori_module_post_condition(self): self.del_resource_modele([15, 16]) self.user_quit() self.login_sysadmin() self.del_res_group([1]) self.del_user_group([1]) self.del_user_data_module([20, 21, 22, 23, 24]) self.user_quit() #------------------------------命令规则前置条件----------------------------------- def commandrule_module_prefix_condition(self): self.login_sysadmin() #添加用户 self.add_user_data_module([25]) self.user_quit() self.login_secadmin() #添加资源 self.add_resource_modele([3]) #添加资源账号 self.add_res_account_module([4]) #添加授权 self.add_authorization_module([2]) #切换到规则定义 self.switch_to_moudle(u'运维管理', u'规则定义') self.command.click_left_rule(0) def commandrule_module_post_condition(self): #删除授权 self.del_authorization_module([2]) #删除资源 self.del_resource_modele([3]) self.user_quit() self.login_sysadmin() #删除用户 self.del_user_data_module([25]) self.user_quit() #------------------------------时间规则前置条件----------------------------------- def timerule_module_prefix_condition(self): self.login_secadmin() #添加用户 self.add_user_data_module([26, 27, 28, 29, 30]) #切换到规则定义 self.switch_to_moudle(u'运维管理', u'规则定义') self.command.click_left_rule(1) def timerule_module_post_condition(self): #删除用户 self.del_user_data_module([26, 27, 28, 29, 30]) self.user_quit() #------------------------------地址规则前置条件----------------------------------- def addressrule_module_prefix_condition(self): self.login_secadmin() #添加用户 self.add_user_data_module([31, 32, 33, 34, 35, 36, 37, 38]) #切换到规则定义 self.switch_to_moudle(u'运维管理', u'规则定义') self.command.click_left_rule(2) def addressrule_module_post_condition(self): self.del_user_data_module([31, 32, 33, 34, 35, 36, 37, 38]) self.user_quit() #------------------------------资源时间规则前置条件----------------------------------- def retimerule_module_prefix_condition(self): self.login_sysadmin() #添加用户 self.add_user_data_module([39]) self.user_quit() self.login_secadmin() #添加资源 self.add_resource_modele([4, 5, 10]) #添加资源账号 self.add_res_account_module([5, 6, 14]) self.add_authorization_module([6]) #切换到规则定义 self.switch_to_moudle(u'运维管理', u'规则定义') self.command.click_left_rule(3) def retimerule_module_post_condition(self): self.user_quit() self.login_sysadmin() #删除用户 self.del_user_data_module([39]) self.user_quit() self.login_secadmin() #删除资源 self.del_resource_modele([4, 5, 10]) #删除授权 self.del_authorization_module([6]) self.user_quit() #------------------------------流程前置条件----------------------------------- def process_module_prefix_condition(self): self.login_sysadmin() #添加用户 self.add_user_data_module([40, 41, 42, 43, 44]) self.user_quit() self.login_secadmin() #添加资源 self.add_resource_modele([11, 12]) #添加资源账号 self.add_res_account_module([15, 16]) self.add_authrization([1]) def process_module_post_condition(self): #删除授权 self.del_authorization_module([7]) #删除资源 self.del_resource_modele([11, 12]) self.user_quit() self.login_sysadmin() #删除用户 self.del_user_data_module([40, 41, 42, 43, 44]) self.user_quit() #------------------------------双人授权前置条件----------------------------------- def dualmandate_module_prefix_condition(self): self.login_sysadmin() #添加用户 self.add_user_data_module([45, 46]) self.user_quit() self.login_secadmin() #添加资源 self.add_resource_modele([13]) #添加资源账号 self.add_res_account_module([17]) #添加授权 self.add_authrization([4]) def dualmandate_module_post_condition(self): #删除授权 self.del_authorization_module([8]) #删除资源 self.del_resource_modele([13]) self.user_quit() self.login_sysadmin() #删除用户 self.del_user_data_module([45, 46]) self.user_quit() #-----------------------------行为报表前置条件--------------------------------- def opt_report_module_prefix_condition(self): self.login_secadmin() self.add_resource_modele([18]) self.user_quit() self.login_sysadmin() self.add_user_data_module([47]) self.add_res_group([2]) self.add_user_group([2]) self.user_quit() self.login_sysaudit() self.switch_to_moudle(u"报表管理", u"审计报表") def opt_report_module_post_condition(self): self.user_quit() self.login_secadmin() self.del_resource_modele([18]) self.user_quit() self.login_sysadmin() self.del_user_data_module([47]) self.del_res_group([2]) self.del_user_group([2]) self.user_quit() #-----------------------------配置报表前置条件--------------------------------- def conf_report_module_prefix_condition(self): self.login_sysadmin() self.add_user_data_module([48]) self.add_user_group([3]) self.user_quit() self.login_sysaudit() self.switch_to_moudle(u"报表管理", u"审计报表") def conf_report_module_post_condition(self): self.user_quit() self.login_sysadmin() self.del_user_data_module([48]) self.del_user_group([3]) self.user_quit() #-----------------------------配置审计前置条件------------------------------ def system_log_prefix_condition(self): self.login_sysadmin() self.add_user_data_module([49]) self.switch_to_moudle(u"系统配置", u"关联服务") self.ntp.click_left_moudle(1) #填写syslog信息 self.frameElem.from_frame_to_otherFrame("rigthFrame") self.syslog.set_ip("172.16.10.11") self.syslog.set_ident("aa") self.syslog.save_button() self.cmf.click_login_msg_button() self.user_quit() self.login_sysaudit() self.switch_to_moudle(u"审计管理", u"配置审计") def system_log_post_condition(self): self.user_quit() self.login_sysadmin() self.del_user_data_module([49]) self.user_quit() #-----------------------------运维审计前置条件------------------------------ def audit_log_prefix_condition(self): self.login_and_switch_to_dep() self.add_user_data_module([43]) self.add_resource_modele([22]) self.add_res_account_module([20]) self.add_authorization_module([9]) self.switch_to_operation() self.sso_module([1]) self.user_quit() #新添加的运维管理员登录 self.sso_user_login(43) self.sso_module([1]) #新添加的运维管理员退出 self.user_quit() self.login_and_switch_to_sys() self.switch_to_moudle(u"审计管理", u"运维审计") def audit_log_post_condition(self): self.sys_switch_to_dep() self.del_authorization_module([9]) self.del_resource_modele([22]) self.del_user_data_module([43]) self.user_quit() #------------------------------命令单点登录前置条件---------------------------- u'''单点登录前置条件''' def sso_prefix_condition(self): self.login_and_switch_to_dep() self.add_resource_modele([1, 3, 4, 5]) self.add_res_account_module([1, 2, 4, 5, 6, 7]) self.add_authorization_module([1]) self.switch_to_operation() #self.user_quit() #self.login_and_switch_to_common() u'''单点登录后置条件''' def sso_post_condition(self): self.user_quit() self.login_and_switch_to_dep() self.del_resource_modele([1, 3, 4, 5]) self.del_authorization_module([1]) self.user_quit() #------------------------------windows单点登录前置条件------------------------- u'''windows单点登录前置条件''' def windows_sso_prefix_condition(self): self.login_and_switch_to_sys() #配置认证方式 self.add_meth_method() self.add_user_data_module([42]) self.sys_switch_to_dep() #self.login_and_switch_to_dep() self.add_resource_modele([2, 7, 8]) self.add_res_account_module([3, 9, 10]) self.add_authorization_module([3, 4]) self.switch_to_operation() #self.user_quit() #self.login_and_switch_to_common() u'''单点登录后置条件''' def windows_sso_post_condition(self): self.user_quit() self.login_and_switch_to_dep() self.del_authorization_module([3, 4]) self.del_user_data_module([42]) self.del_resource_modele([8, 7, 2]) self.user_quit() #------------------------------数据库单点登录前置条件------------------------- u'''数据库单点登录前置条件''' def database_sso_prefix_condition(self): #使用公共用户登录系统 self.login_and_switch_to_sys() #添加应用发布 self.add_application([2]) #添加客户端 self.add_client_module([1, 2]) self.sys_switch_to_dep() self.add_database_res_module([1, 2, 3]) self.add_res_account_module([11, 12, 13]) self.add_authorization_module([5]) self.switch_to_operation() u'''数据库单点登录后置条件''' def database_sso_post_condition(self): self.user_quit() self.login_and_switch_to_dep() self.del_authorization_module([5]) self.del_resource_modele([19, 20, 21]) self.dep_switch_to_sys() self.del_application([2]) self.del_client_module([1, 2]) self.user_quit()
class LinuxResource(object): def __init__(self, driver): self.driver = driver self.frameElem = frameElement(driver) self.resource = Resource(driver) self.account = Accountmgr(driver) u'''添加和编辑Linux资源 Parameters: - data:excel中的一行数据 ''' def add_edit_linux_resource(self, data): self.frameElem.from_frame_to_otherFrame("mainFrame") #资源名称 self.resource.set_resource_name(data[3]) #资源ip self.resource.set_resource_ip(data[4]) #归属部门 if data[5] != 'no': self.resource.set_depart(data[5]) self.resource.select_all_agreement() #从IP if data[6] != 'no': self.resource.set_resource_fortIps(data[6]) #系统版本 if data[7] != 'no': self.resource.set_sys_version(data[7]) #密码策略 if data[8] != 'no': self.resource.select_pwd_strategy(data[8]) #改密驱动名称 if data[9] != 'no': self.resource.set_changePwd_driver(data[9]) #管理员帐号 if data[10] != 'no': self.resource.click_account_sync() self.resource.set_admin_account(data[10]) #管理员口令 if data[11] != 'no': self.resource.set_admin_pwd(data[11]) #口令确认 if data[12] != 'no': self.resource.set_confirm_pwd(data[12]) self.resource.click_up_super() #提权账号口令 self.resource.set_super_pwd(data[13]) #确认口令 self.resource.set_super_confirm_pwd(data[14]) self.resource.click_save_button() u'''校验Linux资源 Parameters: - datarow:excel数据位于第几行 - data:excel中的一行数据 ''' def check_linux_resource(self, datarow, data): self.frameElem.from_frame_to_otherFrame("mainFrame") #资源名称 self.resource.set_resource_name(data[2]) #资源ip self.resource.set_resource_ip(data[3]) #协议类型 if data[4] != 'no': self.resource.select_agreement(data[4]) #协议类型 端口 if datarow == 7: self.resource.set_port(data[4], data[5]) if datarow == 8: self.resource.clear_port("Ssh1") if datarow == 9: self.resource.set_port("Ssh1", data[5]) if datarow == 12: self.resource.click_account_sync() self.resource.click_up_super() if datarow == 13: #提权账号口令 if data[6] != 'no': self.resource.set_super_pwd(data[6]) #确认口令 if data[7] != 'no': self.resource.set_super_confirm_pwd(data[7]) self.resource.set_super_prompt() self.resource.click_save_button() u'''添加资源账号 Parameters: - editacttname:编辑的资源账号名称 - value:选择编辑方式的value值 - addactname:填写的资源账号名称 - pwd:账号口令 - cmfpwd:确认口令 ''' def add_edit_resource_account(self, editacttname='no', value='no', addactname='no', pwd='no', cmfpwd='no'): self.account.click_account_add_edit_button(editacttname) if value != 'no': self.account.select_edit_way(value) if addactname != 'no': self.account.set_account_name(addactname) if pwd != 'no': self.account.set_account_pwd(pwd) if cmfpwd != 'no': self.account.set_account_confirm_pwd(cmfpwd) self.account.set_authorize() self.account.click_save_account() u'''校验资源账号 Parameters: - value:选择编辑方式的value值 - addactname:填写的资源账号名称 - pwd:账号口令 - cmfpwd:确认口令 ''' def check_resource_account(self, value='no', addactname='no', pwd='no', cmfpwd='no'): if addactname == 'no': self.account.clear_account_name() if pwd == 'no': self.account.clear_account_pwd() if cmfpwd == 'no': self.account.clear_account_confirm_pwd() if value != 'no': self.account.select_edit_way(value) if addactname != 'no': self.account.set_account_name(addactname) if pwd != 'no': self.account.set_account_pwd(pwd) if cmfpwd != 'no': self.account.set_account_confirm_pwd(cmfpwd) self.account.set_authorize() self.account.click_save_account()