Selenium常用的三种等待方式

等待

在做自动化测试,设计测试用例的时候,有时下一步的操作会依赖上一步的结果或者内容,上一步操作成功之后才能进行下一步操作等,这时候,我们就需要使用等待,来判断上一步操作是否完成,什么时候可以进行下一步操作。
如果说上一步操作如果花费的时间较长,还没有完成,就去进行下一步操作,这时就会产生无法定位到对象,对象状态不正确,数据校验结果不正确等异常情况。
最后总结:等待可以提高UI自动化代码的稳定性,让代码能够

固定等待
固定等待是脚本中比较常见的一种等待方式,它是利用线程的原理将整个线程后面的代码延迟执行。这种等待可以说比较的霸道,属于强制性等待,目前它是使用最简单的一种办法,强制让浏览器等待X秒,不管当前操作是否完成,是否可以进行下一步操作,都必须等X秒的时间。
缺点:不能准确把握需要等待的时间(有时操作还未完成,等待就结束了,导致报错;有时操作已经完成了,但等待时间还没有到,浪费时间),如果在用例中大量使用,会浪费不必要的等待时间,影响测试用例的执行效率。
优点:使用简单,可以在调试时使用。

import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;

public class sleep {

public static void main(String[] args) throws InterruptedException {
        // TODO Auto-generated method stub
    String chromePath=System.getProperty("user.dir")
            +"\\driver\\chromedriver.exe";
    System.setProperty("webdriver.chrome.driver", chromePath);
    WebDriver driver=new ChromeDriver();
    driver.manage().window().maximize();
    driver.get("https://www.baidu.com");
        /*
         * 强制等待5秒
         */
Thread.sleep(5000);

    driver.get("https://www.jd.com");
    }

}

注意:Thread.sleep(int);方法是以毫秒为计量单位的;

隐藏式等待
隐藏式等待是指设置了一个最长等待时间,如果在规定时间内网页加载完成,则执行下一步,否则一直等到时间结束,然后执行下一步操作。
缺点:使用隐式等待,程序会一直等待整个页面加载完成,才会执行下一步操作;但有时候页面想要的对象早已经加载完成了,但是因为网页上个别对象还没有加载完成,仍要等到页面全部完成才能执行下一步,使用也不是很灵活。
优点:隐性等待对整个driver的周期都起作用,所以只要设置一次即可。
方法:driver.manage().timeouts().implicitlyWait(int, TimeUnit.SECONDS);

import java.util.concurrent.TimeUnit;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;

public class hiedWait {

public static void main(String[] args) {
        // TODO Auto-generated method stub
String chromePath=System.getProperty("user.dir")
                +"\\driver\\chromedriver.exe";
    System.setProperty("webdriver.chrome.driver", chromePath);
    WebDriver driver=new ChromeDriver();
    driver.manage().window().maximize();
    driver.get("https://www.baidu.com");
        /*
         * 隐藏式等待5秒
         */
driver.manage().timeouts().implicitlyWait(5, TimeUnit.SECONDS);

}

}

显式等待
配合until或者until_not方法,再辅助以一些判断条件,就可以构成这样一个场景:每经过多少秒就查看一次locator的对象是否可见,如果可见就停止等待,如果不可见就继续等待直到超过规定的时间后,报超时异常;当然也可以判断某对象是否在规定时间内不可见等等的各种场景吧,需要根据你自己实际的场景选择判断条件;

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;
import org.openqa.selenium.support.ui.ExpectedCondition;
import org.openqa.selenium.support.ui.WebDriverWait;

public class showWait {

public static void main(String[] args) {
        // TODO Auto-generated method stub
String chromePath=System.getProperty("user.dir")
        +"\\driver\\chromedriver.exe";
System.setProperty("webdriver.chrome.driver", chromePath);
WebDriver driver=new ChromeDriver();
driver.manage().window().maximize();
driver.get("https://www.baidu.com");
WebDriverWait wait=new WebDriverWait(driver, 10);
        /*
         * 通过WebDriverWait对象实现,每500毫秒扫描界面是否出现“新闻”对象,未发现的话等待10秒(计算从开始扫描到结束时间)
         */
WebElement wl = wait.until(new ExpectedCondition<WebElement>() {  
public WebElement apply(WebDriver d) {  
    return d.findElement(By.linkText("新闻"));  
            }  
    });

}

}

猜你喜欢

转载自blog.51cto.com/13740529/2114806