UI“三重天”之selenium--常用API和问题处理(三)

时间:2021-09-22 22:07:05

Selenium常用API:

前面两篇示例代码中用到了一些selenium的API方法,例如定位元素的八种方法、访问url、等待、操作浏览器、获取title、点击、清理等等。

有关于selenium的常用API在园子中有写的非常详细的文章。先贴大佬文章地址:https://www.cnblogs.com/Ming8006/p/5727542.html#c1.5。

对于几种用的比较多的地方再记录一下:

等待:

  显式等待:等待条件成立,再继续执行

  示例代码中含有显式等待: 

// Google's search is rendered dynamically with JavaScript.
// Wait for the page to load, timeout after 10 seconds
(new WebDriverWait(driver, 10)).until(new ExpectedCondition<Boolean>() {
    public Boolean apply(WebDriver d) {
        return d.getTitle().toLowerCase().startsWith("cheese!");
    }
});

  官方文档说明:An explicit wait is code you define to wait for a certain condition to occur before proceeding further in the code. The worst case of this is Thread.sleep(), which sets the condition to an exact time period to wait. There are some convenience methods provided that help you write code that will wait only as long as required. WebDriverWait in combination with ExpectedCondition is one way this can be accomplished.【一句话概括“等待条件发生,再继续执行的代码”】 

WebDriver driver = new FirefoxDriver();
driver.get("http://somedomain/url_that_delays_loading");
WebElement myDynamicElement = (new WebDriverWait(driver, 10))
  .until(ExpectedConditions.presenceOfElementLocated(By.id("myDynamicElement"))) 

  在抛出TimeoutException之前最多等待10s,或者在10s发现元素则返回。ExpectedCondition函数返回类型为true或非null对象。

  在实例中无需实例化:

WebDriverWait wait = new WebDriverWait(driver, 10);
WebElement element = wait.until(ExpectedConditions.elementToBeClickable(By.id("someid")));

  

  隐式等待:通过设定的时长等待页面元素加载完成,再执行;如果超过设定时间,则继续执行。

  官方文档示例代码:

WebDriver driver = new FirefoxDriver();
driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);
driver.get("http://somedomain/url_that_delays_loading");
WebElement myDynamicElement = driver.findElement(By.id("myDynamicElement"));

  隐式等待方法关键字:implicitlyWait,直接调用即可。

  该实例等待10s,10s内元素加载完成则继续。

  

  强制等待:lang包下的Thread.sleep()方法,该方法应该也是debug用的最多的一种。

鼠标悬浮:

  在定位元素时,通常有些元素需要执行鼠标悬浮操作。

  使用action包下perform方法:  

    //鼠标悬浮
    public void hover(String xpath) {
        Actions action = new Actions(driver);
        try {
            action.moveToElement(driver.findElement(By.xpath(xpath))).perform();
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

文件上传:

  文件上传可直接使用sendkeys传入需要上传文件的本地路径即可。

  切记:使用该方法,定位到的元素该标签必须是input类型、type=file属性,满足该条件即可用到该方法。  

driver.findElement(By.xpath(xpath)).sendKeys(filePath);

  filepath为本地文件路径及文件名。

截图:

  通常执行自动化测试脚本并非一帆风顺,或者发现流程上的一些错误等等,这个时候便需要增加一些截图,执行完成之后人为进行检查。

  官方文档给出了示例代码:  

import java.net.URL;

import org.openqa.selenium.OutputType;
import org.openqa.selenium.TakesScreenshot;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.remote.Augmenter;
import org.openqa.selenium.remote.DesiredCapabilities;
import org.openqa.selenium.remote.RemoteWebDriver;

public class Testing {
    
    public void myTest() throws Exception {
        WebDriver driver = new RemoteWebDriver(
                                new URL("http://localhost:4444/wd/hub"), 
                                DesiredCapabilities.firefox());
        
        driver.get("http://www.google.com");
        
        // RemoteWebDriver does not implement the TakesScreenshot class
        // if the driver does have the Capabilities to take a screenshot
        // then Augmenter will add the TakesScreenshot methods to the instance
        WebDriver augmentedDriver = new Augmenter().augment(driver);
        File screenshot = ((TakesScreenshot)augmentedDriver).
                            getScreenshotAs(OutputType.FILE);
    }
}

  可以看的出该处用到的是augment,中间的注释指的是如果驱动程序确实有能力进行截屏,然后Augmenter会将TaksCyEnScript方法添加到实例中。

调用JS:

  有时候需要利用JS来执行赋值、点击操作等。

  使用的是JavascriptExecutor,copy一下上方链接那位大佬的示例代码。 

    private static void runJSTest1(WebDriver driver) throws InterruptedException {
        String js ="alert(\"hello,this is a alert!\")";
        ((org.openqa.selenium.JavascriptExecutor) driver).executeScript(js);
        Thread.sleep(2000);
    }
    
    private static void runJSTest2(WebDriver driver)
            throws InterruptedException {
        driver.get("https://www.baidu.com/");
        String js ="arguments[0].click();";
        driver.findElement(By.id("kw")).sendKeys("JAVA");
        WebElement searchButton = driver.findElement(By.id("su"));
        ((org.openqa.selenium.JavascriptExecutor) driver).executeScript(js,searchButton);
        Thread.sleep(2000);
    }

浏览器滚动:

  一样使用的是JavascriptExecutor。  

JavascriptExecutor js = (JavascriptExecutor)driver;
String jscmd = "window.scrollTo(0," + height + ")";
            js.executeScript(jscmd);

进入iframe子页面:

  通常一些元素会在iframe的标签下,那么便需要进入iframe再进行定位:  

WebElement frame = driver.findElement(By.xpath());
            driver.switchTo().frame();

下拉框:

  针对下拉框selenium使用select。  

Select userselect = new Select(driver.findElement(By.xpath()));
            userselect.selectByVisibleText();

切换浏览器窗口:

  webdriver中包含getWindowHandles方法。通过窗口标题去判断切换浏览器的窗口  

    public void switchWindow(String target) {
        //创建 一个字符串便于之后存放句柄
        String s = null;
        //获取当前界面中的句柄
        Set<String> handles = driver.getWindowHandles();
        //循环尝试,找到目标浏览器的句柄
        for(String t :handles) {
            //遍历每一个句柄,判断窗口的标题是否含有预期字符
            System.out.println(t);
            if (driver.switchTo().window(t).getTitle().equals(target)) {
                s = t;
            }
        }
        //切换到目标句柄的界面中
        try {
            driver.switchTo().window(s);
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

加载cookie:

//addcookie方法
driver.manage.addcookie()
//使用option读取用户文件,本地路径 ChromeOptions o = new ChromeOptions(); o.addArguments(“本地路径”)

 

后续~~~~