在 Web UI 自动化测试的过程中,通常会测试页面在不同分辨率下的显示效果,即在不同大小的显示器上全屏浏览器后的页面展示,此种测试方法需要购置不同大小的显示器,或者频繁的设置屏幕分辨率,不仅浪费了大量的金钱,同时也需要有人值守,从而使测试变成了半自动化,背离了自动化测试的初衷,也在一定程度上困扰了一定的自动化测试人员。
其实,不同分辨率下的测试,在一定程度上可以看做是浏览器窗口最大化后,浏览器可显示区域的页面样式兼容性测试。此文通过设置浏览器页面显示区域大小,从而摆脱上述种种问题的束缚。只需要测试人员配置一台比较大的显示屏,将分辨率设置到最大,然后在启动浏览器的时候,设置其对应页面显示区域的大小即可。非常的方便,而且实现了无人值守测试网站在不同分辨率下页面样式展示兼容性的问题。
可参考之前的几篇博文(浏览器窗口大小 获取 及 设置 、获取浏览器显示区域大小【通过 WebDriver,通过 JavaScript】)简述了浏览器窗口大小的获取和设置,以及通过 WebDriver 或 JS 获取浏览器显示区域大小。
上码咯,尽情驰骋吧!
/**
* Set display screen size
*
* @author Aaron.ffp
* @version V1.0.0: autoSeleniumDemo main.aaron.sele.core SeleniumCore.java setBrowserScreenSize, 2015-7-28 20:52:23 Exp $
*
* @param width : screen width
* @param height : screen height
*/
public void setBrowserScreenSize(int width, int height){
// get width and height of window
int win_width = this.webdriver.manage().window().getSize().getWidth();
int win_height = this.webdriver.manage().window().getSize().getHeight(); // get width and height display area
int dis_width = this.getBrowserDisplayAreaSizeByJS()[0];
int dis_height = this.getBrowserDisplayAreaSizeByJS()[1]; // calculate screen width
int screen_width = width + win_width - dis_width; // calculate screen height
int screen_height = height + win_height - dis_height; this.setBrowserSize(screen_width, screen_height);
}
测试源码如下所示:
public class Test_setBrowserScreenSize extends SeleniumCore{
private String baseUrl = "http://www.yixun.com/"; @Test
public void test_setBrowserScreenSize(){
this.webdriver = new ChromeDriver(); this.webdriver.get("http://www.baidu.com"); this.setBrowserScreenSize(800, 600);
}
}
实际测试结果如下所示:
至此,WebUI 自动化功能测试脚本第 020-JavaScript 在 Selenium 自动化中的应用实例之二(获取浏览器显示区域大小) 顺利完结,希望此文能够给初学 Selenium 的您一份参考。
最后,非常感谢亲的驻足,希望此文能对亲有所帮助。热烈欢迎亲一起探讨,共同进步。非常感谢! ^_^