背景:
最近开始拾起RF框架的UI自动化,碰到了一些问题,于是用一个简单的用例来总结一下。
需求:
测试百度首页的热搜超链接是否正确。
分析:
首先我们要登录到百度首页;然后会发现首页中有多个热搜链接,F12观察发现这几个链接的元素可以用同一个css表达式来选中:css=.hotsearch-item .title-content-title,所以我们不必要一个个去点击,可以用Get WebElements关键字来获取存放到一个列表中,去遍历该列表从而减少冗余的操作
实现过程:
1.定位元素:
这里我使用css选择器,当然其他的定位方法也可以使用,css=.hotsearch-item .title-content-title
2.使用Get WebElements关键字来获取元素
${elements} Get WebElements css=.hotsearch-item .title-content-title
3.遍历列表,设置断言,将首页的元素对应text与链接后的网页title进行对比(这里需要注意的是,有几个热搜链接的网页标题与首页热搜标题有出入,可以采取其他方法去进行对比)
注意事项:
1.增加必要的等待时间
2.点击链接后会弹出新的windows窗口,所以我们要通过网页标题来切换窗口,具体做法是
具体关键词的用法可以百度;需要注意的是,我们关闭了第二个窗口后,代码并不知道我们下一次循环要在第一个,即首页进行操作,代码仍然会停留在第二个窗口,所以我们需要把它转到第一个窗口去,使用select window关键字。如果不进行转移,那么会报错提示该窗口已关闭不存在,因为我们已经把第二个关了。
具体代码:
校验百度首页热搜新闻链接正确性
#访问百度首页
Open Browser https://www.baidu.com chrome
Maximize Browser Window
Set Browser Implicit Wait 5
#获取首页的热搜新闻元素的标题
${elements} Get WebElements css=.hotsearch-item .title-content-title
${count} Get Length ${elements}
FOR ${num} IN RANGE ${count}
${title_before} Get Text ${elements[${num}]}
Log ${elements[${num}]}
Click Element ${elements[${num}]}
Sleep 2
${titles} Get Window Titles
Should Start With ${titles[1]} ${title_before}
Select Window title=${titles[1]}
Close Window
Select Window title=${titles[0]}
END