*** Settings *** Resource ../RE0_Common/KeyWord.robot # 公共关键字 Resource ../RE0_Common/ElementPath.robot # 公共元素 Resource ElementPathXC.robot # CShenTong元素 Library Selenium2Library Library string Library DateTime Library DatabaseLibrary *** Keywords *** 创建数据表 [Arguments] ${ip} ${user} ${pwd} Open Connection ${ip} SSHLibrary.Login ${user} ${pwd} Run Keyword And Ignore Error Execute Command /opt/ShenTong/bin/isql -d OSRDB -U SYSDBA/szoscar55 -c "drop table xiba" Execute Command /opt/ShenTong/bin/isql -d OSRDB -U SYSDBA/szoscar55 -c "create table xiba(a VARCHAR(10));" Execute Command /opt/ShenTong/bin/isql -d OSRDB -U SYSDBA/szoscar55 -c "insert into xiba values('xibalasi');" Execute Command \cp /opt/ShenTong/admin/system.conf.bak /opt/ShenTong/admin/system.conf Execute Command rm -rf /opt/agent/ubackup/uagent/lib/VolumeCopy/diskMutex/#* Close Connection 删除数据表 [Arguments] ${ip} ${user} ${pwd} Open Connection ${ip} SSHLibrary.Login ${user} ${pwd} Run Keyword And Ignore Error Execute Command /opt/ShenTong/bin/isql -d OSRDB -U SYSDBA/szoscar55 -c "drop table xiba" Close Connection Sleep 2s 校验数据表 [Arguments] ${ip} ${user} ${pwd} Open Connection ${ip} SSHLibrary.Login ${user} ${pwd} ${sql_result}= Execute Command /opt/ShenTong/bin/isql -d OSRDB -U SYSDBA/szoscar55 -c "select * from xiba;" Should Contain ${sql_result} xiba Close Connection 插入数据表 [Arguments] ${ip} ${user} ${pwd} Open Connection ${ip} SSHLibrary.Login ${user} ${pwd} Run Keyword And Ignore Error Execute Command /opt/ShenTong/bin/isql -d OSRDB -U SYSDBA/szoscar55 -c "insert into xiba select * from xiba" Close Connection ShenTong备份 [Arguments] ${ShenTong_Agent} ${DB_User} ${DB_PWD} ${DB_Instance} ${mds_name} ${encryption_attr} ${compress_attr} ${dedup_attr} ${binpath} 元素点击 ${CDM_dataProtect} 点击副本数据保护成功 定位副本数据保护定位失败 ${date} Evaluate time.strftime('%Y%m%d%H%M%S',time.localtime()) time ${random_strategyName}= Catenate SEPARATOR=_ ShenTong ${date} ${createpolicy} Catenate SEPARATOR= 新建了策略[ ${random_strategyName} Set Suite Variable ${random_strategyName} Set Suite Variable ${createpolicy} Sleep 5s 元素点击 xpath=//span[text()="${ShenTong_agent}"] 点击选择代理 定位代理所在位置失败 sleep 2s 元素点击 ${Add_CDM_BK_Policy} 点击添加策略 点击添加策略定位失败 元素点击 ${Module_ST} 选择ShenTong数据库 定位选择ShenTong数据库类型失败 元素输入 ${Input_celuename} ${random_strategyName} 定位策略名输入框失败 元素输入 ${Input_ST_Usename} ${DB_User} 定位用户名输入框失败 元素输入 ${Input_ST_Pwd} ${DB_PWD} 定位密码输入框失败 元素输入 ${Input_ST_Instance} ${DB_Instance} 定位实例名输入框失败 元素点击 ${ShenTong_setting} 点击高级设置 定位高级设置失败 元素输入 ${kingbase_bin} ${binpath} 定位安装路径的bin目录失败 元素点击 ${Connection credentials_Next} 点击下一步 定位连接凭据下一步失败 元素点击 ${ST_BK_Target} 点击勾选要备份的数据库 定位数据库前勾选框失败 元素点击 ${Target_database_Next_ST} 点击下一步 定位目标数据库下一步失败 元素点击 ${AddTaskCycle} 点击添加任务周期 定位添加任务周期按钮失败 元素点击 ${Cycle_Onetime} 选择仅备份一次 定位一次循环模式定位失败 元素点击 ${Cycle_Confirm} 点击确定完成任务周期设置 定位搜索确定按钮失败 元素点击 ${Cycle_Nextstep} 点击下一步 定位搜索下一步按钮失败 元素点击 ${Input_Choose_MDS} 选择手动指定MDS介质 定位手动选择MDS介质选项失败 元素点击 ${Select_MDS_CDM} 点击展开介质选项下拉框 定位介质下拉框失败 元素点击 xpath=//select[@id="dialogues_addCycleStorage_storagePath_selectMedia_selectedMdsIP_select"]/option[@label="${mds_name}"] 点击选择指定介质 定位指定介质失败 元素点击 ${Storage_Nextstep} 点击下一步进入备份高级选项 定位备份集存储下一部失败 Run Keyword If ${encryption_attr}==1 加密 ... ELSE Log 不勾选加密 Run Keyword If ${compress_attr}==1 压缩 ... ELSE Log 不勾选压缩 Run Keyword If ${dedup_attr}==1 重删 ... ELSE Log 不勾选重删 sleep 2s 元素点击 ${Complete_Add_Policy} 点击完成策略创建 定位策略完成失败 Sleep 2s 元素点击 ${Add_Confirm} 策略确定创建完毕 定位策略创建成功弹窗失败 sleep 5s 元素点击 ${CDM_BK} 点击进入副本数据一栏 定位备份集栏失败 元素输入 ${Input_Policy_Name} ${random_strategyName} 定位策略搜索框失败 Log 输入策略名进行搜索 Sleep 15s FOR ${n} IN RANGE 100 Click Element ${Button_Searchbk} ${bk_status} Run Keyword And Return Status Wait Until Element Is Visible xpath=//tr[1]/td[12]/div[text()="已完成"] Run Keyword If "${bk_status}"=="True" Exit For Loop ... ELSE Log 备份未完成 Sleep 30s END Run Keyword If ${bk_status}==False Fail ... ELSE Log 备份成功 Sleep 15s ShenTong恢复 [Arguments] ${DB_User} ${DB_PWD} ${DB_Instance} 元素点击 ${CDM_BK} 点击副本数据成功 定位副本数据界面失败 sleep 4 元素点击 ${Select_Restore_Option} 点击操作成功 定位操作按钮失败 元素点击 ${Select_Restore} 点击恢复按钮成功 定位恢复按钮失败 sleep 10 元素输入 ${Recover_ST_User} ${DB_User} 定位恢复数据库用户名输入框失败 元素输入 ${Recover_ST_PWD} ${DB_PWD} 定位恢复数据库密码输入框失败 元素输入 ${Recover_ST_Instance} ${DB_Instance} 定位恢复数据库实例名输入框失败 元素点击 ${Recover_Setting} 点击进入恢复高级设置 点击高级设置失败 元素输入 ${Recover_BinPath} ${ShenTong_IntallPath_L} 定位恢复数据库实例名输入框失败 元素点击 ${Recover_Nextstep} 点击下一步进入恢复高级选项 定位下一步失败 元素点击 ${ShenTong_recovery_finish} 点击执行按钮成功 定位执行按钮失败 元素点击 ${confirm_restore} 点击确认恢复按钮成功 点击确认恢复按钮失败 sleep 5 元素点击 ${Add_Confirm} 恢复任务添加完成 定位添加恢复任务成功按钮失败 Log 开始恢复...... 元素点击 ${Select_JobHtml} 点击作业界面成功 定位作业界面失败 sleep 600s Wait Until Page Contains Element ${Search_Status_Sessuss} 300s 恢复未完成 Log 恢复成功 立刻执行 元素点击 ${cdm_tab_policy} 切换到副本保护策略栏 定位副本保护策略功能栏失败 元素点击 ${Complie_execute} 点击策略立即执行 定位立即执行失败 元素点击 ${ST_selectType} 点击展开立即执行下拉框 定位立即执行备份类型失败 元素点击 ${STIncremental_Backup} 点击选择永久增量备份 定位永久增量备份失败 元素点击 ${Confirm_Exec} 点击确定按钮 点击确定按钮 Sleep 5s 元素点击 ${Add_Confirm} 点击确定按钮 定位确定按钮失败 元素点击 ${CDM_BK} 点击进入备份集一栏 定位备份集栏失败 Sleep 600s Wait Until Page Contains Element xpath=//tr[1]/td[12]/div[text()="已完成"] 180s 备份未完成 Log 备份完成 ShenTong挂载 [Arguments] ${binpath} 元素点击 ${CDM_BK} 点击副本数据成功 定位副本数据界面失败 sleep 2 元素点击 ${Select_Restore_Option} 点击操作成功 定位操作按钮失败 元素点击 ${Backups_Mount} 点击挂载按钮成功 定位挂载按钮失败 元素输入 ${mount_STBinPath} ${binpath} 定位安装路径的bin目录失败 元素点击 ${ShenTong_recovery_finish} 点击执行成功 定位执行按钮失败 元素点击 ${mount_finish} 点击完成成功 定位完成按钮失败 元素点击 ${Add_Confirm} 点击添加成功确定按钮成功 点击添加成功确定按钮失败 元素点击 ${Select_JobHtml} 点击作业界面成功 定位作业界面失败 sleep 60s Wait Until Page Contains Element ${Search_Status_Sessuss} 300s 挂载未完成 Log 挂载99%成功 ShenTong停止挂载 元素点击 ${CDM_mount} 点击副本应用成功 点击副本应用失败 元素点击 ${CDM_umount} 点击卸载按钮成功 定位卸载按钮失败 元素点击 ${umount_sure} 点击完成成功 定位完成失败 元素点击 ${Add_Confirm} 点击卸载成功按钮成功 定位卸载成功按钮失败 Log 卸载挂载成功 ShenTong环境清理 元素点击 ${cdm_tab_policy} 切换到副本保护策略栏 定位副本保护策略功能栏失败 元素点击 ${Cycle_Police_Delete} 点击删除 点击删除成功 元素点击 ${CDM_Police_Delete} 点击确认删除成功 定位确认按钮失败 元素点击 ${Success_Confirm} 点击删除成功 定位删除成功按钮失败 Log 环境清理完毕 重删 元素点击 ${Select_dedup} 点击数据重删 定位数据重删失败 加密 元素点击 ${Pipeline_Encryption} 点击加密 定位数据加密失败 压缩 元素点击 ${Pipeline_Compress} 点击数据压缩 定位数据压缩失败 ShenTong停库 [Arguments] ${Host_IP} ${Host_User} ${Host_PWD} Open Connection ${Host_IP} 22 log ShenTong用户登录远程测试机器 SSHLibrary.Login ${Host_User} ${Host_PWD} log 停止神通数据库 Execute Command /etc/init.d/oscaragentd stop Execute Command /etc/init.d/oscardb_OSRDBd stop Close Connection ShenTong启库 [Arguments] ${Host_IP} ${Host_User} ${Host_PWD} Open Connection ${Host_IP} 22 log ShenTong用户登录远程测试机器 SSHLibrary.Login ${Host_User} ${Host_PWD} log 启动神通数据库 Execute Command /etc/init.d/oscaragentd start Execute Command /etc/init.d/oscardb_OSRDBd start Close Connection 校验数据表_挂载 [Arguments] ${ip} ${user} ${pwd} Open Connection ${ip} SSHLibrary.Login ${user} ${pwd} ${sql_result}= Execute Command /opt/ShenTong/bin/isql -d OSRDB0 -U SYSDBA/szoscar55 -c "select * from xiba;" Should Contain ${sql_result} xiba Close Connection