robotframework-demo/Project/task4/Resource/RE2_CDM/KeyWord_shenTong.robot

202 lines
11 KiB
Plaintext

*** 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