zTree 东西不多,我也一直使用着原始的人工测试手段,随着内容的不断增多,测试起来就越发的繁杂,而且经常犯懒,这样就会忽略很多本该发现的问题,而且也容易出现旧的bug 反复出现的情况,这都是测试不规范造成的。要做好东西就要更加规范和严格,于是乎决定要学习一下 Selenium WebDriver,也就是原先的  Selenium v2 了,这方面整体的文章并不多,所以一边学着,自己一边整理吧。

对于这个可以自动化测试的工具( Selenium WebDriver)我就不做过多描述了,去 google、baidu 搜索一下即可。 我这里只记录学习  Selenium WebDriver 的过程,尤其是运行时可能出现的问题,当然了,我是做java的,我只学习 java 与  Selenium WebDriver 配合的方法。

一、下载文件

先要去官网(http://seleniumhq.org/download/)下载必需的文件:

Selenium IDE (专门用于 FireFox 测试的独立界面,可以录制测试步骤,但我更倾向于写代码做标准的功能测试)
Selenium Server (可以输入指令控制、可以解决跨域的 js 问题,等到后面学到了再讲吧)
The Internet Explorer Driver Server (专门用于IE测试的)
Selenium Client Drivers (可以找到你熟悉的语言,例如我选择的 Java)
Third Party Browser Drivers NOT SUPPORTED/DEVELOPED by seleniumhq(第三方开发的 Selenium 插件,第一个就是 Chrome 的,否则你就没办法测试 Chrome 了)
其他的,就根据你自己的需要寻找吧,目前这些足够我用了。

二、安装 & 运行

貌似摆弄新东西时,只有 “Hello World” 蹦出来以后,我们这些初学者才会感到情绪稳定,那就赶紧开始吧。

对于初期打算直接用编程方式制作测试用例的情况来说,Selenium IDE、Selenium Server 都可以不用安装执行。
英语好的朋友可以直接看官网的文档(http://seleniumhq.org/documentation/)就能够开始使用了。
看中文的,就继续听我唠叨:

【1. 建立 Maven 工程】
Selenium 支持 maven 工程,这会让你的工作更加简便。
用 Eclipse 建个 Maven 的工程,建成后,直接修改 pom.xml,(参考:http://seleniumhq.org/docs/03_webdriver.html#setting-up-a-selenium-webdriver-project)

Xml代码  收藏代码
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.fahai</groupId>
  <artifactId>selenium</artifactId>
  <version>0.0.1-SNAPSHOT</version>
        
         <dependencies>  
        <dependency>  
            <groupId>org.seleniumhq.selenium</groupId>  
            <artifactId>selenium-java</artifactId>  
            <version>2.43.1</version>  
        </dependency>  
        <dependency>  
            <groupId>junit</groupId>  
            <artifactId>junit</artifactId>  
            <version>4.8.2</version>  
            <scope>test</scope>  
        </dependency>  
    </dependencies>  
</project>
pom.xml 修改保存后,eclipse 会自动把需要的 jar 包下载完成。
 
【2. 测试 FireFox】
Selenium 最初就是在 FireFox 上做起来的插件,所以我们先来搭建 FireFox 的环境。
确保你正确安装了 FireFox 后,就可以直接编写 java 代码测试喽。

在 lesson1 目录下建立 ExampleForFireFox.java
(因为国内不少朋友访问 google 的时候会出问题,所以我就把代码中的 google 变成 baidu 了)

Java代码  收藏代码
package lesson1;  
  
import org.openqa.selenium.By;  
import org.openqa.selenium.WebDriver;  
import org.openqa.selenium.WebElement;  
import org.openqa.selenium.firefox.FirefoxDriver;  
import org.openqa.selenium.support.ui.ExpectedCondition;  
import org.openqa.selenium.support.ui.WebDriverWait;  
  
public class ExampleForFireFox  {  
    public static void main(String[] args) {  
        // 如果你的 FireFox 没有安装在默认目录,那么必须在程序中设置  
//      System.setProperty("webdriver.firefox.bin", "D:\\Program Files\\Mozilla Firefox\\firefox.exe");  
        // 创建一个 FireFox 的浏览器实例  
        WebDriver driver = new FirefoxDriver();  
  
        // 让浏览器访问 Baidu  
        driver.get("http://www.baidu.com");  
        // 用下面代码也可以实现  
        // driver.navigate().to("http://www.baidu.com");  
  
        // 获取 网页的 title  
        System.out.println("1 Page title is: " + driver.getTitle());  
  
        // 通过 id 找到 input 的 DOM  
        WebElement element = driver.findElement(By.id("kw"));  
  
        // 输入关键字  
        element.sendKeys("zTree");  
  
        // 提交 input 所在的  form  
        element.submit();  
          
        // 通过判断 title 内容等待搜索页面加载完毕,Timeout 设置10秒  
        (new WebDriverWait(driver, 10)).until(new ExpectedCondition<Boolean>() {  
            public Boolean apply(WebDriver d) {  
                return d.getTitle().toLowerCase().endsWith("ztree");  
            }  
        });  
  
        // 显示搜索结果页面的 title  
        System.out.println("2 Page title is: " + driver.getTitle());  
          
        //关闭浏览器  
        driver.quit();  
    }  
}  
 
普通情况下,直接运行代码就可以看到会自动弹出 FireFox 窗口,访问 baidu.com,然后输入关键字并查询,一切都是自动完成的。

错误提醒:
1)Exception in thread "main" org.openqa.selenium.WebDriverException: Cannot find firefox binary in PATH. Make sure firefox is installed.
出现这个错误,是说明你的 FireFox 文件并没有安装在默认目录下,这时候需要在最开始执行:System.setProperty 设置环境变量  "webdriver.firefox.bin" 将自己机器上 FireFox 的正确路径设置完毕后即可。

2)Exception in thread "main" org.openqa.selenium.UnsupportedCommandException: Bad request
出现这个错误,很有意思。 查了一下 有人说应该是 hosts 出现了问题,加上一个 127.0.0.1  localhost 就行了,但我的 hosts 上肯定有这个玩意,为啥也会出现这个问题呢?

经过调试,发现 127.0.0.1 localhost 的设置必须要在 hosts 文件的最开始,而且如果后面有其他设置后,也不要再出现同样的 127.0.0.1 localhost ,只要有就会出错。(因为我为了方便访问 google 的网站,专门加入了 smarthosts 的内容,导致了 localhost 的重复)

【3. 测试 Chrome】
Chrome 虽然不是 Selenium 的原配,但是没办法,她太火辣了,绝对不能抛下她不管的。
把 ExampleForFireFox.java 稍微修改就可以制作出一个 ExampleForChrome.java ,直接把 new FireFoxDriver() 修改为 new ChromeDriver() 你会发现还是行不通。

错误如下:
1)Exception in thread "main" java.lang.IllegalStateException: The path to the driver executable must be set by the webdriver.chrome.driver system property; for more information, see http://code.google.com/p/selenium/wiki/ChromeDriver. The latest version can be downloaded from http://code.google.com/p/chromedriver/downloads/list
这应该是找不到 chrome 的文件,好吧,利用 System.setProperty 方法添加路径,这里要注意,是 “webdriver.chrome.driver” 可不是“webdriver.chrome.bin”

设置路径后还是会报错:
2)[6416:4580:1204/173852:ERROR:gpu_info_collector_win.cc(91)] Can't retrieve a valid WinSAT assessment.
这个貌似是因为 Selenium 无法直接启动 Chrome 导致的,必须要通过前面咱们下载 Chrome 的第三方插件 ChromeDriver,去看第一个错误中提示给你的 网址:http://code.google.com/p/selenium/wiki/ChromeDriver
按照人家给的例子来修改我们的测试代码吧:

Java代码  收藏代码
package lesson1;  
  
import java.io.File;  
import java.io.IOException;  
  
import org.openqa.selenium.By;  
import org.openqa.selenium.WebDriver;  
import org.openqa.selenium.WebElement;  
import org.openqa.selenium.chrome.ChromeDriverService;  
import org.openqa.selenium.remote.DesiredCapabilities;  
import org.openqa.selenium.remote.RemoteWebDriver;  
import org.openqa.selenium.support.ui.ExpectedCondition;  
import org.openqa.selenium.support.ui.WebDriverWait;  
  
public class ExampleForChrome {  
    public static void main(String[] args) throws IOException {  
        // 设置 chrome 的路径  
        System.setProperty(  
                "webdriver.chrome.driver",  
                "C:\\Documents and Settings\\sq\\Local Settings\\Application Data\\Google\\Chrome\\Application\\chrome.exe");  
        // 创建一个 ChromeDriver 的接口,用于连接 Chrome  
        @SuppressWarnings("deprecation")  
        ChromeDriverService service = new ChromeDriverService.Builder()  
                .usingChromeDriverExecutable(  
                        new File(  
                                "E:\\Selenium WebDriver\\chromedriver_win_23.0.1240.0\\chromedriver.exe"))  
                .usingAnyFreePort().build();  
        service.start();  
        // 创建一个 Chrome 的浏览器实例  
        WebDriver driver = new RemoteWebDriver(service.getUrl(),  
                DesiredCapabilities.chrome());  
  
        // 让浏览器访问 Baidu  
        driver.get("http://www.baidu.com");  
        // 用下面代码也可以实现  
        // driver.navigate().to("http://www.baidu.com");  
  
        // 获取 网页的 title  
        System.out.println("1 Page title is: " + driver.getTitle());  
  
        // 通过 id 找到 input 的 DOM  
        WebElement element = driver.findElement(By.id("kw"));  
  
        // 输入关键字  
        element.sendKeys("zTree");  
  
        // 提交 input 所在的 form  
        element.submit();  
  
        // 通过判断 title 内容等待搜索页面加载完毕,Timeout 设置10秒  
        (new WebDriverWait(driver, 10)).until(new ExpectedCondition<Boolean>() {  
            public Boolean apply(WebDriver d) {  
                return d.getTitle().toLowerCase().endsWith("ztree");  
            }  
        });  
  
        // 显示搜索结果页面的 title  
        System.out.println("2 Page title is: " + driver.getTitle());  
  
        // 关闭浏览器  
        driver.quit();  
        // 关闭 ChromeDriver 接口  
        service.stop();  
  
    }  
}  
 
运行一下看看,是不是一切OK了?

【2012.12.06补充】

上一个 Demo 中无法正常使用 new ChromeDriver(),今天在做进一步学习时看到一篇文章(http://qa.blog.163.com/blog/static/19014700220122231779/​),恍然大悟,原来只需要把 ‘webdriver.chrome.driver​’ 的值设置为 chromedriver 的路径就可以了。
 
 
Java代码  收藏代码
package lesson1;  
  
import java.io.IOException;  
  
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 ExampleForChrome2 {  
    public static void main(String[] args) throws IOException {  
        // 设置 chrome 的路径  
        System.setProperty(  
                "webdriver.chrome.driver",  
                "E:\\Selenium WebDriver\\chromedriver_win_23.0.1240.0\\chromedriver.exe");  
        // 创建一个 ChromeDriver 的接口,用于连接 Chrome  
        // 创建一个 Chrome 的浏览器实例  
        WebDriver driver = new ChromeDriver();  
  
        // 让浏览器访问 Baidu  
        driver.get("http://www.baidu.com");  
        // 用下面代码也可以实现  
        // driver.navigate().to("http://www.baidu.com");  
  
        // 获取 网页的 title  
        System.out.println("1 Page title is: " + driver.getTitle());  
  
        // 通过 id 找到 input 的 DOM  
        WebElement element = driver.findElement(By.id("kw"));  
  
        // 输入关键字  
        element.sendKeys("zTree");  
  
        // 提交 input 所在的 form  
        element.submit();  
  
        // 通过判断 title 内容等待搜索页面加载完毕,Timeout 设置10秒  
        (new WebDriverWait(driver, 10)).until(new ExpectedCondition<Boolean>() {  
            public Boolean apply(WebDriver d) {  
                return d.getTitle().toLowerCase().endsWith("ztree");  
            }  
        });  
  
        // 显示搜索结果页面的 title  
        System.out.println("2 Page title is: " + driver.getTitle());  
  
        // 关闭浏览器  
        driver.quit();  
  
        // element = driver.findElement(By.id("kw"));  
        // // element.clear();  
        // element.click();  
        // element.clear();  
        // element.sendKeys("zTree");  
        // element.submit();  
    }  
}  
【4. 测试 IE】
想逃避 IE 吗?? 作为前端开发,IE 你是必须要面对的,冲吧!
其实你会发现, Selenium 主要也就是针对 FireFox 和 IE 来制作的,所以把 FireFox 的代码修改为 IE 的,那是相当的容易,只需要简单地两步:
1)把 ExampleForFireFox.java 另存为 ExampleForIE.java 
2)把 WebDriver driver = new FirefoxDriver(); 修改为 WebDriver driver = new InternetExplorerDriver();
3)一般大家的 IE都是默认路径吧,所以也就不用设置 property 了

Java代码  收藏代码
package lesson1;  
  
import org.openqa.selenium.By;  
import org.openqa.selenium.WebDriver;  
import org.openqa.selenium.WebElement;  
import org.openqa.selenium.ie.InternetExplorerDriver;  
import org.openqa.selenium.support.ui.ExpectedCondition;  
import org.openqa.selenium.support.ui.WebDriverWait;  
  
public class ExampleForIE {  
    public static void main(String[] args) {  
        // 如果你的 FireFox 没有安装在默认目录,那么必须在程序中设置  
        // System.setProperty("webdriver.firefox.bin", "D:\\Program Files\\Mozilla Firefox\\firefox.exe");  
        // 创建一个 FireFox 的浏览器实例  
        WebDriver driver = new InternetExplorerDriver();  
  
        // 让浏览器访问 Baidu  
        driver.get("http://www.baidu.com");  
        // 用下面代码也可以实现  
        // driver.navigate().to("http://www.baidu.com");  
  
        // 获取 网页的 title  
        System.out.println("1 Page title is: " + driver.getTitle());  
  
        // 通过 id 找到 input 的 DOM  
        WebElement element = driver.findElement(By.id("kw"));  
  
        // 输入关键字  
        element.sendKeys("zTree");  
  
        // 提交 input 所在的 form  
        element.submit();  
  
        // 通过判断 title 内容等待搜索页面加载完毕,Timeout 设置10秒  
        (new WebDriverWait(driver, 10)).until(new ExpectedCondition<Boolean>() {  
            public Boolean apply(WebDriver d) {  
                return d.getTitle().toLowerCase().endsWith("ztree");  
            }  
        });  
  
        // 显示搜索结果页面的 title  
        System.out.println("2 Page title is: " + driver.getTitle());  
  
        // 关闭浏览器  
        driver.quit();  
    }  
}  
 
运行一下,是不是 so easy?

Selenium WebDriver(1)——入门篇相关推荐

  1. Python使用Selenium WebDriver的入门介绍及安装教程

    Selenium WebDriver 入门 一.什么是Selenium WebDriver 二.安装Selenium WebDriver 2.1 安装selenium类库 2.2 安装浏览器驱动 2. ...

  2. 和我一起学 Selenium WebDriver(1)——入门篇

    一.下载文件 先要去官网(http://seleniumhq.org/download/)下载必需的文件: Selenium IDE (专门用于 FireFox 测试的独立界面,可以录制测试步骤,但我 ...

  3. 自动化测试工具 Selenium WebDriver 入门教程

    <div class="iteye-blog-content-contain" style="font-size: 14px"></div&g ...

  4. 用 python selenium 爬简书,Python自动化领域之 Selenium WebDriver 学习第2篇

    本篇博客使用 selenium 实现对简书官网的操作. 文章目录 通过 selenium 执行 JS selenium 实现简书搜索 selenium 隐式与显式等待 selenium 采集京东图书 ...

  5. 通过简书网学习 ActionChains,selenium webdriver 学习第3篇

    本篇博客学习 selenium webdriver 控制窗口句柄,以及模拟鼠标键盘操作等内容. 控制 BOSS 直聘网站窗口句柄 本次先通过 BOSS 直聘网进行测试,打开网站首页的头图. 切换句柄, ...

  6. tampermonkey油猴与selenium webdriver入门 (by quqi99)

    作者:张华 发表于:2020-11-08 版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本版权声明 今天群里在给同学投票,有人点50次,于是,研究了一下. tamperm ...

  7. selenium webdriver入门

    ​概要 WebDriver可以像用户一样驱动原生浏览器,无论是在本地服务器还是在使用Selenium服务器的远程机器上,都标志着浏览器自动化的一个飞跃. Selenium WebDriver也是控制浏 ...

  8. element 登录_Python selenium自动化测试框架入门实战--登录测试案例

    本文为Python自动化测试框架基础入门篇,主要帮助会写基本selenium测试代码又没有规划的同仁. 本文应用到POM模型.selenium.unittest框架.configparser配置文件. ...

  9. web 自动化测试(入门篇)

    自动化测试入门篇 本次实现自动化是用python语言进行实现,所以需要有一点python基础,其实python还是比较简单入门的,下面开始. 安装python,我安装的是最新版本的python,传送门 ...

最新文章

  1. 【百度分享】以太网卡TSO技术浅析
  2. 虚拟搭建局域网模拟器_接上U盘就能构建虚拟局域网!蒲公英X5路由器使用体验分享...
  3. STM32F4 HAL库开发 -- STM32F407引脚图
  4. 使用pycharm配置flask项目,并使用git进行版本控制
  5. 矩阵每一行重复_【剑指offer】65 矩阵中的路径
  6. 这个工具可以组合参数画出2种单细胞Marker显示图
  7. autohold有什么弊端吗_自动驻车AUTO HOLD有啥作用?怎样使用?
  8. 自制TXT文本分割工具
  9. 人人商城小程序消息服务器配置,人人商城小程序前端对接教程
  10. android studio 打包生成apk文件
  11. vue中使用router打开一个新的窗口
  12. Kinect2.0-Python调用-PyKinect2
  13. 第二节课 上身肌肉锻炼
  14. windows10 安装两台mysql进行主从复制
  15. 辅流式沉淀池固体负荷计算方法_20000m3/d污水厂设计计算书
  16. CSS3如何横向居中+纵向居中 in grid container
  17. Opus:IETF低延迟音频编解码器:API和操作手册
  18. 倍福PLC模拟量输入模块的使用方法
  19. Softing新版HART多路复用器软件支持西门子控制器
  20. 阿里云物联网平台添加网关设备和子设备

热门文章

  1. Linux挂载移动群晖硬盘,通过USB移动硬盘盒挂载群晖格式硬盘的方法
  2. 会员等级进度功能前端实现
  3. 追加贷显示服务器出错,小蜜蜂财务软件常见问题汇总
  4. i5-1135g7是标压还是低压 i5 1135g7是集成显卡么
  5. Open Policy Agent(OPA) rego使用
  6. leetcode刷题目录总结
  7. Arduino红外控制LED灯开关
  8. Hadoop安全认证(2)
  9. MYSQL 回退数据
  10. 【分析BMI指数~python】