robotframework-demo/Project/task4/Resource/RE3_DPM/KeyWord_SQLServer.robot

305 lines
16 KiB
Plaintext
Raw Normal View History

2023-12-14 03:19:52 +00:00
*** Settings ***
Resource ElementPath.robot # DPM xpath路径
Library Selenium2Library
Library DatabaseLibrary
Resource ../RE0_Common/ElementPath.robot # 公共xpath
Resource ../RE0_Common/KeyWord.robot # 公共关键字
*** Keywords ***
SQLServer备份
[Arguments] ${Sqlserver_Agent} ${bk_type} ${mds_name} ${encryption_attr} ${compress_attr} ${dedup_attr} ${check_attr}
[Documentation] 功能添加SQLserver备份策略等待备份完成产生备份集
...
... 使用方法SQLserver备份
...
... 变量:${Sqlserver_Agent}代理名 | ${bk_type}备份类型 | ${mds_name}介质名 | ${encryption_attr}是否加密 | ${compress_attr}是否压缩 | ${dedup_attr}是否重删 | ${check_attr}是否数据校验 | ${cache}是否缓存
元素点击 ${Timed_DataProtect} 点击进入定时数据保护 定位定时数据保护栏失败
${date} Evaluate time.strftime('%Y%m%d%H%M%S',time.localtime()) time
${random_strategyName}= Catenate SEPARATOR=_ ${bk_type} ${date}
${createpolicy} Catenate SEPARATOR= 新建了策略[ ${random_strategyName} ]
Set Suite Variable ${random_strategyName}
Set Suite Variable ${createpolicy}
Sleep 5s
元素点击 xpath=//span[text()="${Sqlserver_Agent}"] 点击选择代理 定位sqlserver代理失败
元素点击 ${Add_Policy} 点击添加策略 定位添加策略按钮失败
元素点击 ${Sqlserver_Module} 点击选择Sqlserver模块 定位sqlserver模块失败
元素输入 ${Input_celuename} ${random_strategyName} 定位策略名输入框失败
元素点击 ${Sqlserver_Conn_NextStep} 点击下一步进入到实例选择页面 定位连接凭据下一步失败
Sleep 5s
元素点击 ${Sqlserver__NextStep} 点击下一步进入到目标数据库选择页面 定位实例选择下一步失败
元素点击 xpath=//span[contains(text(),'yy')]/../..//td[@width="20px"]/div[@class="dhx_bg_img_fix"] 点击勾选数据库 定位要备份的数据库失败
元素点击 ${SQLServer_mbdata next} 点击下一步进入任务周期 定位目标数据库下一步失败
元素点击 ${Add_taskcycle} 点击添加任务周期 定位添加任务周期按钮失败
Run Keyword If "${bk_type}"=="完全" 完全备份
... ELSE IF "${bk_type}"=="差量" 差量备份
... ELSE IF "${bk_type}"=="日志" 日志备份
... ELSE Fail 定位备份类型失败
元素点击 ${Cycle_Once} 设置任务仅执行一次 定位仅执行一次失败
元素点击 ${Cycle_Confirm} 确定任务周期设置完毕 定位任务周期设置失败
元素点击 ${Cycle_NextStep} 点击下一步进入备份集存储设置界面 定位下一步失败
元素点击 ${Manual_ChooseMDS} 点击勾选手动选择介质 定位选择介质失败
元素点击 ${Select_Sqlserver_MDS} 点击介质选择按钮 定位介质选择按钮失败
元素点击 xpath=//select[@id="dialogues_addCycleStorage_storagePath_selectMedia_selectedMdsIP_select"]/option[@label="${mds_name}"] 点击选择指定介质 定位指定介质失败
Run Keyword If ${dedup_attr}==1 重删
... ELSE log 不勾选重删
sleep 5s
元素点击 ${Storage_NextStep} 点击下一步进入到备份高级选项 定位下一步失败
Run Keyword If ${encryption_attr}==1 加密
... ELSE log 不加密
Run Keyword If ${compress_attr}==0 压缩
... ELSE IF ${compress_attr}==1 取消压缩
Run Keyword If ${check_attr}==1 校验
... ELSE log 不进行校验
元素点击 ${Senior_NextStep} 点击下一步进入到消息确认页面 定位备份高级选项下一步失败
元素点击 ${Success_Confirm} 点击确定按钮成功 点击确定按钮失败
sleep 6s
Comment 元素点击 ${Success_Confirm} 确定策略创建成功 策略创建失败
Comment 元素点击 ${BackupSet} 点击进入备份集一栏 定位备份集栏失败
Comment Sleep 60s
Comment Wait Until Page Contains Element Xpath=//td[4][text()="${random_strategyName}"]/..//td[text()="已完成"] 300s 备份未完成
Comment Log 备份完成
Comment Sleep 2s
元素点击 ${BackupSet} 点击进入备份集一栏 定位备份集栏失败
元素输入 ${Input_Policy_Name} ${random_strategyName} 定位策略搜索框失败
Log 输入策略名进行搜索
Sleep 15s
FOR ${n} IN RANGE 20
Click Element ${Button_Searchbk}
${bk_status} Run Keyword And Return Status Wait Until Element Is Visible xpath=//*[@id="backupSetTable"]//tr[2]/td[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
SQLServer恢复
元素点击 ${BackupSet} 点击进入备份集恢复页面 定位备份集栏失败
Sleep 2s
元素点击 ${Click_recover} 点击恢复指定备份集 定位要恢复的备份集失败
Sleep 7s
元素点击 ${Recover_Target_NextStep_Sqlserver} 点击下一步进入到实例选择界面 定位恢复目标下一步失败
元素点击 ${Recover_Instance_NextStep} 点击下一步进入到高级选项界面 定位实例选择界面下一步失败
元素点击 ${Recover_Senior_NextStep} 点击下一步进入到确认恢复界面 定位高级选项下一步失败
元素点击 ${confirm_restore} 点击确定恢复确认按钮成功 点击确定恢复确认按钮失败
元素点击 ${Success_Confirm} 点击确认恢复成功 点击确认恢复失败
sleep 10s
元素点击 ${Policy_Work} 点击进入作业栏 定位作业栏失败
Sleep 60s
Wait Until Page Contains Element ${Recover_Success} 240s 恢复失败
sleep 2s
Log 恢复成功
创建SQLServer数据表
[Arguments] ${Sql_TableName1} ${Sql_IP_Remote} ${Sql_DB_User} ${Sql_DB_PWD} ${Sql_DB} #SQL表名#SQL代理IP#SQL数据库用户#SQL数据库密码#SQL数据库
[Documentation] 功能连接SQLserver数据库删除原有表、新建表后插入数据
...
... 使用方法创建SQLserver数据表 表名
...
... 变量: ${DPM_MSSql_TableName1}表名
Connect To Database Using Custom Params pymssql host='${Sql_IP_Remote}',port='1433',user='${Sql_DB_User}',password='${Sql_DB_PWD}',database='${Sql_DB}',charset='CP936'
${row_count}= Row Count SELECT \ * FROM dbo.SysObjects WHERE ID = object_id(N'${Sql_TableName1}') AND OBJECTPROPERTY(ID, 'IsTable') = 1;
Run Keyword IF ${row_count}>0 Execute Sql String drop table ${Sql_TableName1};
log 执行sql建表
Execute Sql String create table ${Sql_TableName1}(id int,dt int)
log 插入数据
Execute Sql String insert into ${Sql_TableName1} values(1, 11111)
log 建表完成
${row_num}= Row Count select * from ${Sql_TableName1};
log ${row_num}
Disconnect From Database
删除SQLServer数据表
[Arguments] ${Sql_TableName1} ${Sql_IP_Remote} ${Sql_DB_User} ${Sql_DB_PWD} ${Sql_DB} #SQL表名#SQL代理IP#SQL数据库用户#SQL数据库密码#SQL数据库
Connect To Database Using Custom Params pymssql host='${Sql_IP_Remote}',user='${Sql_DB_User}',password='${Sql_DB_PWD}',database='${Sql_DB}'
${row_count} Row Count SELECT \ * FROM dbo.SysObjects WHERE ID = object_id(N'${Sql_TableName1}') AND OBJECTPROPERTY(ID, 'IsTable') = 1;
Run Keyword IF ${row_count}>0 Execute Sql String drop table ${Sql_TableName1};
Disconnect From Database
校验SQLServer数据表
[Arguments] ${Sql_TableName1} ${Sql_IP_Remote} ${Sql_DB_User} ${Sql_DB_PWD} ${Sql_DB} #SQL表名#SQL代理IP#SQL数据库用户#SQL数据库密码#SQL数据库
sleep 10s
Connect To Database Using Custom Params pymssql host='${Sql_IP_Remote}',user='${Sql_DB_User}',password='${Sql_DB_PWD}',database='${Sql_DB}'
log 查询表
${row_num} Row Count select * from ${Sql_TableName1};
log ${row_num}
Disconnect From Database
SQLServer差量备份
元素点击 ${dpm_Protection strategy} 选择定时保护策略 定位定时保护策略失败
元素点击 xpath=//td[text()="${random_strategyName}"]/..//span[text()="立即执行"] 点击立即执行 定位立即执行失败
元素点击 ${Select_BackType} 点击选择备份类型 定位选择备份类型失败
元素点击 ${Now Difference_Backup} 选择差量备份 定位差量备份失败
元素点击 ${Now Sure} 点击立即执行确定 定位立即执行确定失败
元素点击 ${Success_Confirm} 点击确定 定位确定失败
log 开始备份
Sleep 60s
元素点击 ${BackupSet} 点击进入备份集一栏 定位备份集栏失败
Sleep 60s
Wait Until Page Contains Element Xpath=//td[4][text()="${random_strategyName}"]/..//td[text()="SQLServer差量备份"]/..//td[text()="已完成"] 300s 备份未完成
Log 备份完成
Sleep 2s
SQLServer事务备份
元素点击 ${dpm_Protection strategy} 选择定时保护策略 定位定时保护策略失败
元素点击 xpath=//td[text()="${random_strategyName}"]/..//span[text()="立即执行"] 点击立即执行 定位立即执行失败
元素点击 ${Select_BackType} 点击选择备份类型 定位选择备份类型失败
元素点击 ${Now Difference_Backup} 选择差量备份 定位差量备份失败
元素点击 ${Now Sure} 点击立即执行确定 定位立即执行确定失败
元素点击 ${Success_Confirm} 点击确定 定位确定失败
log 开始备份
Sleep 60s
元素点击 ${BackupSet} 点击进入备份集一栏 定位备份集栏失败
Sleep 60s
Wait Until Page Contains Element Xpath=//td[4][text()="${random_strategyName}"]/..//td[text()="SQLServer差量备份"]/..//td[text()="已完成"] 300s 备份未完成
Log 备份完成
Sleep 2s
插入SQLServer数据
[Arguments] ${Sql_TableName1} ${Sql_IP_Remote} ${Sql_DB_User} ${Sql_DB_PWD} ${Sql_DB} #SQL表名#SQL代理IP#SQL数据库用户#SQL数据库密码#SQL数据库
log 连接数据库
Connect To Database Using Custom Params pymssql host='${Sql_IP_Remote}',user='${Sql_DB_User}',password='${Sql_DB_PWD}',database='${Sql_DB}',charset='CP936'
${row_count} Row Count SELECT \ * FROM dbo.SysObjects WHERE ID = object_id(N'${Sql_TableName1}') AND OBJECTPROPERTY(ID, 'IsTable') = 1;
Run Keyword IF ${row_count}>0 Execute Sql String insert into ${Sql_TableName1} values(2, 11111)
log 插入数据
Execute Sql String insert into ${Sql_TableName1} values(3, 11111)
log 数据插入完成
${row_num} Row Count select * from ${Sql_TableName1};
log ${row_num}
Disconnect From Database
完全备份
Sleep 2s
Click Element ${Full_Backup}
Log 勾选完全备份
差量备份
Sleep 2s
Click Element ${Difference_Backup}
Log 勾选差量备份
日志备份
Sleep 2s
Click Element ${SQLServer_sw}
Log 勾选日志备份
加密
元素点击 ${Sqlserver_Encryption} 点击勾选sqlserver加密 定位sqlserver加密选项失败
压缩
Log 点击压缩
重删
Sleep 2s
元素点击 ${Option_Dedup} 勾选重删 定位重删选项失败
Log 点击重删
Sleep 2s
校验
Set Focus To Element ${Option_Check}
Click Element ${Option_Check}
Log 勾选校验选项
Sleep 2s
SQLServer立即执行
[Arguments] ${bk_type} # 立即执行备份类型
元素点击 ${Timed_DataProtect} 点击进入定时数据保护页面 定位定时数据保护失败
元素点击 ${dpm_Protection strategy} 切换到定时保护策略栏 定位定时保护策略功能栏失败
Sleep 2s
元素点击 xpath=//td[text()="${random_strategyName}"]/..//span[text()="立即执行"] 点击策略立即执行 定位立即执行失败
元素点击 ${Select_BackType} 点击展开立即执行下拉框 定位立即执行备份类型失败
Run Keyword If "${bk_type}"=="1" 立即执行_完全
... ELSE IF "${bk_type}"=="2" 立即执行_差量
... ELSE IF "${bk_type}"=="3" 立即执行_事务日志
Sleep 2s
循环点击 ${ExecutePolicy_execute} ${Complie_confirm}
Sleep 5s
元素点击 ${Complie_confirm} 点击确定按钮 定位确定按钮失败
元素点击 ${BackupSet} 点击进入备份集一栏 定位备份集栏失败
Comment Sleep 60s
Comment Wait Until Page Contains Element xpath=//*[@id="backupSetTable"]//tr[2]/td[text()="已完成"] 300s 备份未完成
Comment Log 备份完成
Comment Sleep 5s
元素点击 ${BackupSet} 点击进入备份集一栏 定位备份集栏失败
元素输入 ${Input_Policy_Name} ${random_strategyName} 定位策略搜索框失败
Log 输入策略名进行搜索
Sleep 15s
FOR ${n} IN RANGE 20
Click Element ${Button_Searchbk}
${bk_status} Run Keyword And Return Status Wait Until Element Is Visible xpath=//*[@id="backupSetTable"]//tr[2]/td[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
立即执行_完全
元素点击 ${Now Full_Bacup} 点击立即执行完全备份 定位完全备份选项失败
立即执行_差量
元素点击 ${Now Difference_Backup} 点击立即执行差量备份 定位差量备份选项失败
立即执行_事务日志
元素点击 ${Now SW_Backup} 点击立即执行事务日志备份 定位事务日志备份选项失败
取消压缩
Set Focus To Element ${Option_Compress}
Click Element ${Option_Compress}
Log 取消备份集压缩压缩
备份集属性校验
[Arguments] ${encryption} ${compress} ${deduped}
sleep 2s
元素点击 Xpath=//td[text()="${random_strategyName}"]/..//span[text()="详情"] 点击展开详情 定位详情失败
sleep 5s
Run Keyword If ${encryption}==1 加密属性校验_是
... ELSE 加密属性校验_否
Run Keyword If ${compress}==1 压缩属性校验_是
... ELSE 压缩属性校验_否
Run Keyword If ${deduped}==1 重删属性校验_是
... ELSE 重删属性校验_否
元素点击 ${Attr_Cancel} 点击取消关闭备份集详情弹窗 定位取消按钮失败
Log 备份集属性确认完毕
Sleep 2s
加密属性校验_是
sleep 3s
Element Should Contain ${Encryption_Attr} 是
Log 加密属性校验完毕
加密属性校验_否
sleep 3s
Element Should Contain ${Encryption_Attr} 否
Log 备份集未加密
压缩属性校验_是
sleep 3s
Element Should Contain ${Compress_Attr} 是
Log 压缩属性校验完毕
压缩属性校验_否
sleep 3s
Element Should Contain ${Compress_Attr} 否
Log 备份集未压缩
重删属性校验_是
sleep 3s
Element Should Contain ${SQLserver_Deduped_Attr} 是
Log 重删属性校验完毕
重删属性校验_否
sleep 3s
Element Should Contain ${SQLserver_Deduped_Attr} 否
Log 备份集未重删
缓存属性校验_是
Element Should Contain ${Cache_Attr} 是
Log 缓存属性校验完毕
缓存属性校验_否
Element Should Contain ${Cache_Attr} 否
Log 备份集未设置缓存