UI“三重天”之Selenium(一)

关注一下UI自动化,记一记笔记。

UI自动化的优缺点:

  关于UI自动化的优缺点想来大家都有了解,优点:解放人力(并不是完全解放),用机器(涵盖工具、脚本等)代替人工完成测试工作,将测试用例转化为脚本实现,其大部分的使用阶段在回归测试阶段。缺点:难维护,依赖于前端。

  web端混的风生水起的非Selenium莫属,app端的Uiautomator、appium等等。

UI自动化的核心:

  UI自动化的核心还是定位元素。

Web端“一哥”--Selenium:

了解一项技术,最权威的依然是官方文档,贴传送门:https://www.seleniumhq.org/docs

Selenium工作原理:

  当下用的最多的还是webdriver,那么webdriver是什么东西呢?用来干什么?在web端的UI自动化过程中充当了什么角色?

  webdriver是C/S架构的一套工具,client是编写的自动化脚本代码,server就是由webdriver.exe启动的浏览器,监听来自client发送的消息,并且对其做出响应,从而实现对浏览

器的操作。

  通俗一点webdriver就是快递公司,代码是快递信息,快递员是浏览器。

  寄快递的时候首先要明白的是要通过哪家快递公司去承运(浏览器应该用chrome还是firefox、IE),选好快递公司之后肯定要写清楚收件人的姓名、地址、电话号码(执行代码中要明确请求URL、触发时间、按钮、输入文本等),快递公司会将这些信息传达给快递员,快递员进行送件;其工作机制可能有些许差别,但是理解容易点,大部分都是异曲同工。

有关webdriver和浏览器的不适配问题碰到不止一次有人问,下方贴了chrome和firefox的全部信息,都是百度来的,当个苦力综合一下:

chrome浏览器历史版本下载地址:https://www.chromium.org/getting-involved/dev-channel(国外版)

               https://www.chromedownloads.net/(国内版)

               http://npm.taobao.org/mirrors/chromedriver/

Firefox浏览器历史版本下载地址:http://ftp.mozilla.org/pub/firefox/releases/

chrome驱动下载地址:http://chromedriver.storage.googleapis.com/index.html

Firefox驱动下载地址:https://github.com/mozilla/geckodriver/releases

 

chrome驱动与浏览器对应表:

        chromedriver版本支持的Chrome版本
v2.34 v61-63
v2.33 v60-62
v2.32 v59-61
v2.31 v58-60
v2.30 v58-60
v2.29 v56-58
v2.28 v55-57
v2.27 v54-56
v2.26 v53-55
v2.25 v53-55
v2.24 v52-54
v2.23 v51-53
v2.22 v49-52
v2.21 v46-50
v2.20 v43-48
v2.19 v43-47
v2.18 v43-46
v2.17 v42-43
v2.13 v42-45
v2.15 v40-43
v2.14 v39-42
v2.13 v38-41
v2.12 v36-40
v2.11 v36-40
v2.10 v33-36
v2.9 v31-34
v2.8 v30-33
v2.7 v30-33
v2.6 v29-32
v2.5 v29-32
v2.4 v29-32

以Selenium官方示例代码为例:

         // And now use this to visit Google
        driver.get("https://www.baidu.com");
        // Alternatively the same thing can be done like this
        // driver.navigate().to("http://www.google.com");

        // Find the text input element by its name
        WebElement element = driver.findElement(By.name("wd"));

        // Enter something to search for
        element.sendKeys("桃李不言、下自成蹊 博客园");

        // Now submit the form. WebDriver will find the form for us from the element
        element.submit();

        // Check the title of the page
        System.out.println("Page title is: " + driver.getTitle());
        
        // 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!");
            }
        });

        // Should see: "cheese! - Google Search"
        System.out.println("Page title is: " + driver.getTitle());
        
        //Close the browser
        driver.quit();   
注释写的很明白咯!!,就不一一翻译了。

 原文代码是访问google,改成了baidu,搜索内容以及By.name段更改了value。

 Firefox浏览器运行方式:

  1、增加浏览器安装路径

  2、增加驱动路径 

System.setProperty("webdriver.firefox.bin", "F:\\Firefox\\firefox.exe");
    	System.setProperty("webdriver.gecko.driver", "E:\\driver\\geckodriver.exe");
        WebDriver driver = new FirefoxDriver();

  Chrome浏览器运行方式:

  1、增加驱动路径

System.setProperty("webdriver.chrome.driver", "E:\\driver\\chromedriver.exe");
        WebDriver driver = new ChromeDriver();

   该例有访问URL方式,定位元素方式、传值方式、一处显示等待、打印标题、关闭方式。很直观,不算太难吧?

ps:

浏览器版本与驱动版本不匹配绝对是每个人都会遇到的问题,报错原因千奇百怪。

常见的:WebDriverException: unknown error: call function result missing 'value'

更换浏览器或者驱动版本搞定:http://npm.taobao.org/mirrors/chromedriver/

posted @ 2018-10-10 00:29  紫陌花间客  阅读(347)  评论(0编辑  收藏  举报