【软件测试】webdriver常用API演示(Java+IDEA+chrome浏览器)

1.元素定位方法

对象的定位应该是自动化测试的核心,要想操作一个对象,首先应该识别这个对象。一个对象就是一个人一样,他会有各种的特征(属性),如比我们可以通过一个人的身份证号,姓名,或者他住在哪个街道、楼层、门牌找到这个人。

那么一个对象也有类似的属性,我们可以通过这些属性找到这对象。

注意:不管用那种方式,必须保证页面上该属性的唯一性

webdriver 提供了一系列的对象定位方法,常用的有以下几种:

  • id
  • name
  • class name
  • link text
  • partial link text
  • tag name
  • xpath
  • css selector

1.1 css selector

css选择器,主要使用有类选择器,id选择器,标签选择器,后代选择器。

详细使用可参考这篇文章:5选择器

1.2 xpath定位元素

xpath定位元素是通过路径来定位的,分为绝对路径和相对路径。

xpath的缺点

1.性能差,定位元素的性能要比其它大多数方式差;

2.不够健壮,XPath会随着页面元素布局的改变而改变;

  1. 兼容性不好,在不同的浏览器下对XPath 的实现是不一样的

2.操作测试对象

定位只是第一步,定位之后需要对这个元素进行操作。是鼠标点击还是键盘输入,或者清除元素的内容,或者提交表单等。这个取决于定位元素需要进行的下一步操作。

webdriver 中比较常用的操作对象的方法有下面几个:

  • click 点击对象
  • send_keys 在对象上模拟按键输入
  • clear 清除对象输入的文本内容
  • submit 提交
  • text用于获取元素的文本信息

2.1鼠标点击与键盘输入

通过css选择器定位到"百度一下",点击百度一下:

java 复制代码
    /**
     * 实现点击事件
     * @throws InterruptedException
     */
    private static void test02() throws InterruptedException {
        //创建一个options对象
        ChromeOptions options=new ChromeOptions();
        options.addArguments("--remote-allow-origins=*");
        //设置驱动路径
        System.setProperty("webdriver.chrome.driver","C:\\Program Files\\Java\\jdk1.8.0_192\\bin\\chromedriver.exe");
        WebDriver webDriver=new ChromeDriver(options);
        //打开百度页面
        webDriver.get("https://www.baidu.com");
        //输入软件测试
        webDriver.findElement(By.cssSelector("#kw")).sendKeys("软件测试");
        //点击百度一下
        webDriver.findElement(By.cssSelector("#su")).click();
    }

2.2获取元素文本

通过css选择器定位到"百度一下",获取"百度一下"文本。

java 复制代码
    /**
     * 获取元素文本
     * @throws InterruptedException
     */
    private static void test03() throws InterruptedException {
        ChromeOptions options=new ChromeOptions();
        options.addArguments("--remote-allow-origins=*");
        //设置驱动路径
        System.setProperty("webdriver.chrome.driver","C:\\Program Files\\Java\\jdk1.8.0_192\\bin\\chromedriver.exe");
        WebDriver webDriver=new ChromeDriver(options);
        //打开百度首页
        webDriver.get("https://www.baidu.com");
        //获取文本
        System.out.println(webDriver.findElement(By.cssSelector("#su")).getAttribute("value"));
        sleep(3000);
    }

2.3submit提交表单

submit点击的元素必须放到form标签中,但是click没有要求:

java 复制代码
    private static void test04() {
        ChromeOptions options=new ChromeOptions();
        options.addArguments("--remote-allow-origins=*");
        //设置驱动路径
        System.setProperty("webdriver.chrome.driver","C:\\Program Files\\Java\\jdk1.8.0_192\\bin\\chromedriver.exe");
        WebDriver webDriver=new ChromeDriver(options);
        //打开百度首页
        webDriver.get("https://www.baidu.com");
        webDriver.findElement(By.cssSelector("a.mnav:nth-child(1)")).submit();
    }

3.添加等待

3.1强制等待

通过sleep()方法进行强制等待:

java 复制代码
sleep(3000);

3.2隐式等待

通过添加implicitly_wait() 方法就可以方便的实现智能等待;implicitly_wait(30)的用法比sleep()更智能,后者只能选择一个固定的时间的等待,前者可以在一个时间范围内智能的等待。

java 复制代码
    private static void test06() {
        ChromeOptions options=new ChromeOptions();
        options.addArguments("--remote-allow-origins=*");
        //设置驱动路径
        System.setProperty("webdriver.chrome.driver","C:\\Program Files\\Java\\jdk1.8.0_192\\bin\\chromedriver.exe");
        WebDriver webDriver=new ChromeDriver(options);
        //打开百度首页
        webDriver.get("https://www.baidu.com");
        //找到搜索输入框
        webDriver.findElement(By.cssSelector("#kw")).sendKeys("测试");
        //找到百度一下,点击
        webDriver.findElement(By.cssSelector("#su")).click();
        //在3天内找到了就可以继续运行后面的代码
        webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.DAYS);
        //找到搜索框,清空
        webDriver.findElement(By.cssSelector("#kw")).clear();
    }

3.3显示等待

java 复制代码
    private static void test13() {
        //创建浏览器驱动
        WebDriver webDriver=new ChromeDriver();
        //打开网页
        webDriver.get("https://www.baidu.com/");
        //等待50s
        WebDriverWait wait = new WebDriverWait(webDriver, 50);
        //找一个title
        wait.until(ExpectedConditions.titleIs("百度一下,你就知道"));
    }

3.4显示等待和隐式等待之间的相同点和不同点

相同点:显示等待和隐式等待都属于智能等待

不同点:隐式等待等待的是页面上所有的元素,显示等待只要条件满足即可

4.打印信息

打印百度首页url

java 复制代码
    private static void test07() {
        ChromeOptions options=new ChromeOptions();
        options.addArguments("--remote-allow-origins=*");
        //设置驱动路径
        System.setProperty("webdriver.chrome.driver","C:\\Program Files\\Java\\jdk1.8.0_192\\bin\\chromedriver.exe");
        WebDriver webDriver=new ChromeDriver(options);
        //打开百度首页
        webDriver.get("https://www.baidu.com/");
        //获取url
        String url=webDriver.getCurrentUrl();
        System.out.println(url);
        //如果当前页面url等于https://www.baidu.com,测试通过
        if(url.equals("https://www.baidu.com/")){
            System.out.println("测试通过");
        }else {
            //否则不通过
            System.out.println("测试失败");
        }
    }

打印title:

java 复制代码
    private static void test08() {
        ChromeOptions options=new ChromeOptions();
        options.addArguments("--remote-allow-origins=*");
        //设置驱动路径
        System.setProperty("webdriver.chrome.driver","C:\\Program Files\\Java\\jdk1.8.0_192\\bin\\chromedriver.exe");
        WebDriver webDriver=new ChromeDriver(options);
        //打开百度首页
        webDriver.get("https://www.baidu.com/");
        //获取到当前页面的title
        String title = webDriver.getTitle();
        //如果title等于"百度一下,你就知道",测试成功
        if(title.equals("百度一下,你就知道")){
            System.out.println("测试通过");
        }else {
            //否则失败
            System.out.println("测试失败");
        }
    }

5.浏览器操作

5.1浏览器页面大小

浏览器页面最大化:

java 复制代码
    private static void test09() {
        ChromeOptions options=new ChromeOptions();
        options.addArguments("--remote-allow-origins=*");
        //设置驱动路径
        System.setProperty("webdriver.chrome.driver","C:\\Program Files\\Java\\jdk1.8.0_192\\bin\\chromedriver.exe");
        WebDriver webDriver=new ChromeDriver(options);
        //打开百度首页
        webDriver.get("https://www.baidu.com/");
        //最大化
        webDriver.manage().window().maximize();
    }

设置宽高:

java 复制代码
		//高度和宽度像素点都是500
        webDriver.manage().window().setSize(new Dimension(500,500));

5.2浏览器前进和后退

操作浏览器前进,后退:

java 复制代码
    private static void test10() throws InterruptedException {
        ChromeOptions options=new ChromeOptions();
        options.addArguments("--remote-allow-origins=*");
        //设置驱动路径
        System.setProperty("webdriver.chrome.driver","C:\\Program Files\\Java\\jdk1.8.0_192\\bin\\chromedriver.exe");
        WebDriver webDriver=new ChromeDriver(options);
        //打开百度首页
        webDriver.get("https://www.baidu.com/");
        //输入"测试"
        webDriver.findElement(By.cssSelector("#kw")).sendKeys("测试");
        //点击"百度一下"
        webDriver.findElement(By.cssSelector("#su")).click();
        sleep(3000);
        //后退
        webDriver.navigate().back();
        sleep(3000);
        //前进
        webDriver.navigate().forward();
        sleep(3000);
        //刷新
        webDriver.navigate().refresh();
    }

5.3浏览器控制滚动条

控制浏览器滚动条:

java 复制代码
    private static void test14() {
        //创建浏览器驱动
        WebDriver webDriver=new ChromeDriver();
        //打开网页
        webDriver.get("https://www.baidu.com/");
        //搜索"软件"
        webDriver.findElement(By.cssSelector("#kw")).sendKeys("软件");
        //点击百度一下
        webDriver.findElement(By.cssSelector("su")).click();
        //操作滚动条
        ((JavascriptExecutor)webDriver).executeScript("document.documentElement.scrollTop=10000;");
    }

5.3浏览器关闭

java 复制代码
webdriver.quit();
webdriver.close();

区别:

  • close关闭的是当前页面 ,不会清除cookie这些信息
  • quit关闭的是浏览器,并且会清空cookie

6.键盘组合键用法

通过sendkeys调用按键:

全选:sendKeys(Keys.CONTROL+"A")

剪切:sendKeys(Keys.CONTROL+"X")

粘贴:sendKeys(Keys.CONTROL+"V")

java 复制代码
    private static void test11() throws InterruptedException {
        ChromeOptions options=new ChromeOptions();
        options.addArguments("--remote-allow-origins=*");
        //设置驱动路径
        System.setProperty("webdriver.chrome.driver","C:\\Program Files\\Java\\jdk1.8.0_192\\bin\\chromedriver.exe");
        WebDriver webDriver=new ChromeDriver(options);
        //打开百度首页
        webDriver.get("https://www.baidu.com/");
        webDriver.findElement(By.cssSelector("#kw")).sendKeys("测试");
        //ctrl+a
        webDriver.findElement(By.cssSelector("#kw")).sendKeys(Keys.CONTROL+"A");
        sleep(3000);
        //ctrl+x
        webDriver.findElement(By.cssSelector("#kw")).sendKeys(Keys.CONTROL+"X");
        sleep(3000);
        //ctrl+v
        webDriver.findElement(By.cssSelector("#kw")).sendKeys(Keys.CONTROL+"V");
        sleep(3000);
        webDriver.findElement(By.cssSelector("#su")).click();
    }

7.鼠标事件

通过action移动鼠标,perform()执行所有存储的行为。

java 复制代码
    private static void test12() {
        ChromeOptions options=new ChromeOptions();
        options.addArguments("--remote-allow-origins=*");
        //设置驱动路径
        System.setProperty("webdriver.chrome.driver","C:\\Program Files\\Java\\jdk1.8.0_192\\bin\\chromedriver.exe");
        WebDriver webDriver=new ChromeDriver(options);
        //打开百度首页
        webDriver.get("https://www.baidu.com/");
        webDriver.findElement(By.cssSelector("#kw")).sendKeys("测试");
        webDriver.findElement(By.cssSelector("#su")).click();
        Actions actions=new Actions(webDriver);
        //智能等待
        webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.SECONDS);
        WebElement target=webDriver.findElement(By.cssSelector("a.s-tab-item:nth-child(8)"));
        //移动+执行
        //actions.moveToElement(target).perform();
        //右击
        actions.contextClick(target).perform();
    }

8.定位一组元素

webdriver 可以很方便的使用findElement 方法来定位某个特定的对象,不过有时候我们却需要定位一组对象,这时候就需要使用findElements 方法。

定位一组对象一般用于以下场景:

  • 批量操作对象,比如将页面上所有的checkbox 都勾上
  • 先获取一组对象,再在这组对象中过滤出需要具体定位的一些对象。比如定位出页面上所有的 checkbox,然后选择最后一个

示例:

在下面的页面上,只选中checkbox:

实现代码:

java 复制代码
    private static void page01() {
        ChromeOptions options=new ChromeOptions();
        options.addArguments("--remote-allow-origins=*");
        //设置驱动路径
        System.setProperty("webdriver.chrome.driver","C:\\Program Files\\Java\\jdk1.8.0_192\\bin\\chromedriver.exe");
        WebDriver webDriver=new ChromeDriver(options);
        webDriver.get("http://localhost:63342/selenium-demo01/src/main/page/test01.html?_ijt=kto2ktutimpfs88l655vij1vpc&_ij_reload=RELOAD_ON_SAVE");
        //获取到input标签下面所有的元素
        List<WebElement> elements = webDriver.findElements(By.cssSelector("input"));
        //遍历
        for (int i=0;i<elements.size();i++){
            if(elements.get(i).getAttribute("type").equals("checkbox")){
                //如果是checkbox就点击
                elements.get(i).click();
            }else{
                //什么都不干
            }
        }
    }

9.多层框架定位

对于一个web 应用,经常会出现框架(frame) 或窗口(window)的应用,这也就给我们的定位带来了一定的困难。

  • 定位一个frame :switch_to.frame(name_or_id_or_frame_element)
  • 定位一个窗口window:switch_to.window(name_or_id_or_frame_element)

多层框架定位:

java 复制代码
    private static void page02() {
        //创建浏览器驱动
        WebDriver webDriver=new ChromeDriver();
        //打开网页
        webDriver.get("网页地址");
        //找到click并点击
        //切换到click所在的框架
        webDriver.switchTo().frame("f1");
        //点击
        webDriver.findElement(By.cssSelector("选择器")).click();
    }

10.下拉框定位

下拉框是我们最常见的一种页面元素,对于一般的元素,我们只需要一次就定位,但下拉框里的内容需要进行两次定位,先定位到下拉框对下拉框进行操作后,再定位到下拉框内里的选项。

举例:

java 复制代码
private static void page03() {
        //创建浏览器驱动
        WebDriver webDriver=new ChromeDriver();
        //打开网页
        webDriver.get("http://localhost:63342/selenium-demo01/src/main/page/test03.html?_ijt=f2rop62blqmeft308l6p64ckm6&_ij_reload=RELOAD_ON_SAVE");
        //操作下拉框
        Select select = new Select(webDriver.findElement(By.cssSelector("#ShippingMethod")));
        //根据value获取
        select.selectByValue("9.25");
        //根据下标获取
        select.selectByIndex(2);
    }

11.alert弹窗

针对一个普通的alert弹窗的操作:

  • 点击确定
  • 点击取消
  • 输入信息
java 复制代码
    private static void page04() {
        //创建浏览器驱动
        WebDriver webDriver=new ChromeDriver();
        //打开网页
        webDriver.get("http://localhost:63342/selenium-demo01/src/main/page/test04.html?_ijt=kh3uv3t7rfg891ma2uiqgfveo2&_ij_reload=RELOAD_ON_SAVE");
        //点击按钮
        webDriver.findElement(By.cssSelector("button")).click();
        //alert弹窗->确定
        webDriver.switchTo().alert().accept();
        //alert弹窗->取消
        webDriver.switchTo().alert().dismiss();
        //alert弹窗->输入信息
        webDriver.switchTo().alert().sendKeys("输入了一个文字信息");
    }

12.文件提交

java 复制代码
    private static void page05() {
        //创建浏览器驱动
        WebDriver webDriver=new ChromeDriver();
        //打开网页
        webDriver.get("网址");
        //点击按钮(上传文件)
        webDriver.findElement(By.cssSelector("input")).sendKeys("文件路径");
    }

13.截图

先引入commons-io依赖:

java 复制代码
        <!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.11.0</version>
        </dependency>

实现代码:

java 复制代码
    private static void test15() throws IOException {
        //创建浏览器驱动
        WebDriver webDriver=new ChromeDriver();
        //打开网页
        webDriver.get("https://www.baidu.com/");
        //截图
        File src_file=((TakesScreenshot)webDriver).getScreenshotAs(OutputType.FILE);
        //保存截图
        FileUtils.copyFile(src_file,new File("地址"));
    }

14.窗口切换

打开百度首页->点击新闻->页面跳转到新闻页->点击音乐->跳转到音乐页面:

java 复制代码
private static void test17() {
        ChromeOptions options=new ChromeOptions();
        options.addArguments("--remote-allow-origins=*");
        //设置驱动路径
        System.setProperty("webdriver.chrome.driver","C:\\Program Files\\Java\\jdk1.8.0_192\\bin\\chromedriver.exe");
        WebDriver webDriver=new ChromeDriver(options);
        //打开网页
        webDriver.get("https://www.baidu.com/");
        //点击新闻
        webDriver.findElement(By.cssSelector("a.mnav:nth-child(1)")).click();
        //获取到浏览器所有的窗口句柄
        Set<String> windowHandles = webDriver.getWindowHandles();
        String target_handle="";
        //遍历
        for(String handle:windowHandles){
            //拿到最后点击的窗口
            target_handle=handle;
        }
        //窗口转换
        webDriver.switchTo().window(target_handle);
        //点击新闻中的音乐按钮
        webDriver.findElement(By.cssSelector("#header-link-wrapper > li:nth-child(5) > a:nth-child(1)")).click();
    }
相关推荐
hanbarger13 分钟前
mybatis框架——缓存,分页
java·spring·mybatis
cdut_suye20 分钟前
Linux工具使用指南:从apt管理、gcc编译到makefile构建与gdb调试
java·linux·运维·服务器·c++·人工智能·python
苹果醋332 分钟前
2020重新出发,MySql基础,MySql表数据操作
java·运维·spring boot·mysql·nginx
小蜗牛慢慢爬行34 分钟前
如何在 Spring Boot 微服务中设置和管理多个数据库
java·数据库·spring boot·后端·微服务·架构·hibernate
azhou的代码园37 分钟前
基于JAVA+SpringBoot+Vue的制造装备物联及生产管理ERP系统
java·spring boot·制造
18号房客44 分钟前
macOS开发环境配置与应用开发教程(一)
vscode·macos·visualstudio·eclipse·intellij-idea·phpstorm·visual studio
wm10431 小时前
java web springboot
java·spring boot·后端
smile-yan1 小时前
Provides transitive vulnerable dependency maven 提示依赖存在漏洞问题的解决方法
java·maven
老马啸西风1 小时前
NLP 中文拼写检测纠正论文-01-介绍了SIGHAN 2015 包括任务描述,数据准备, 绩效指标和评估结果
java
Earnest~1 小时前
Maven极简安装&配置-241223
java·maven