【自动化测试】——Selenium (基于java)

这篇具有很好参考价值的文章主要介绍了【自动化测试】——Selenium (基于java)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

小亭子正在努力的学习编程,接下来将开启软件测试的学习~~

分享的文章都是学习的笔记和感悟,如有不妥之处希望大佬们批评指正~~

同时如果本文对你有帮助的话,烦请点赞关注支持一波, 感激不尽~~

目录

一、认识Selenium

1.什么是自动化测试 

2.Selenium

 3.webdriver的工作原理:

二、环境搭建

1.下载chrome浏览器

2.查看chrome浏览器版本

3. 下载chrome浏览器驱动

4.配置环境变量

5.验证环境是否搭建成功

三、Selenium常用API

1.定位元素

2.操作对象

3.添加等待

4.打印信息

5.浏览器操作

6.键盘操作

7.鼠标操作

8.定位一组元素

9.下拉框处理

10.切换窗口句柄

11.操作截图

12.上传文件操作

四、常见面试题


一、认识Selenium

1.什么是自动化测试 

 自动化测试指软件测试的自动化,在预设状态下运行应用程序或者系统,预设条件包括正常和异常,最后评估运行结果。将人为驱动的测试行为转化为机器执行的过程。

【简单来说就是编写代码,让机器代替人工进行测试工作】

selenium-java,测试,selenium,测试工具

2.Selenium

Seleniumweb应用中基于UI的自动化测试框架,支持多平台、多浏览器、多语言。

早期的selenium RC已经被现在的webDriver所替代,可以简单的理解为selenium1.0+webdriver构成现在的Selenium2.0。现在我们说起selenium,一般指的是Selenium2.0。它有由Selenium IDE,Webdriver,Selenium Grid组成。

 分别做一下介绍:

2.1Selenium IDE

Selenium IDE一个用于Selenium测试的完成集成开发环境,可以直接录制在浏览器的用户操作,并且能回放,编辑和调试测试脚本。调试过程中可以逐步进行或调整执行的速度,并且可以在底部浏览日志出错信息。录制的测试脚本可以以多种语言导出,比如java,C#PythonRuby等,方便掌握不同语言的测试人员操作。

2.2Webdriver

Selenium RC 在浏览器中运行 JavaScript 应用,会存在环境沙箱问题,而WebDriver可以跳出JavaScript的沙箱,针对不同的浏览器创建更健壮的,分布式的,跨平台的自动化测试脚本。基于特定语言(JavaC#PythonRubyPerlJavaScript等)绑定来驱动浏览器对Web元素进行操作和验证。

 3.webdriver的工作原理:

启动浏览器后,selenium-webdriver会将目标浏览器绑定到特定的端口,启动后的浏览器则作为

webdriverremote server

客户端(也就是测试脚本),借助ComandExecutor发送HTTP请求给sever端(通信协议:The

WebDriver Wire Protocol,在HTTP requestbody中,会以WebDriver Wire协议规定的JSON

式的字符串来告诉Selenium我们希望浏览器接下来做什么事情)。

Sever端需要依赖原生的浏览器组件,转化Web Service的命令为浏览器native的调用来完成操作。


二、环境搭建

这里我使用的是:Chrome+Java(推荐)

1.下载chrome浏览器

下载链接已准备好selenium-java,测试,selenium,测试工具

https://www.google.cn/intl/zh-CN/chrome/

2.查看chrome浏览器版本

selenium-java,测试,selenium,测试工具

 selenium-java,测试,selenium,测试工具

3. 下载chrome浏览器驱动

链接已备好selenium-java,测试,selenium,测试工具https://chromedriver.chromium.org/downloadsselenium-java,测试,selenium,测试工具

selenium-java,测试,selenium,测试工具

4.配置环境变量

解压下载好的驱动压缩包,将下载好的chromedriver.exe放到java系统环境变量下

举例:我的java路径是C:\Program Files\Java\jdk1.8.0_131\bin

selenium-java,测试,selenium,测试工具

5.验证环境是否搭建成功

(1)创建java项目,添加pom文件中添加依赖

<!-- https://mvnrepository.com/artifact/org.seleniumhq.selenium/selenium-java -->
<dependency>
    <groupId>org.seleniumhq.selenium</groupId>
    <artifactId>selenium-java</artifactId>
    <version>3.141.59</version>
</dependency>

(2)编写代码运行

public class Demo2 {
    public static void main(String[] args) {
        // 谷歌驱动
        ChromeOptions options = new ChromeOptions();
        // 允许所有请求
        options.addArguments("--remote-allow-origins=*");
        WebDriver webDriver = new ChromeDriver(options);
        // 启动需要打开的网页
        webDriver.get("https://www.baidu.com");
    }
}

selenium-java,测试,selenium,测试工具

显示上述图片内容后,浏览器就会自动启动,注意仔细观察。

selenium-java,测试,selenium,测试工具


三、Selenium常用API

1.定位元素

id

findElement(By.id())

name

findElement(By.name())

class name

findElement(By.className())

tag name

findElement(By.tagName())

link text

findElement(By.linkText())

partial link text

findElement(By.partialLinkText())

xpath

findElement(By.xpath())

css selector

findElement(By.cssSelector())

         //引入谷歌驱动
        ChromeOptions options = new ChromeOptions();
        //允许所有请求
        options.addArguments("--remote-allow-origins=*");
        WebDriver webDriver = new ChromeDriver(options);
        //启动需要打开的网页
        webDriver.get("https://www.baidu.com");
        // 利用id定位元素:百度输入框,并在输入框中输入:软件测试
        webDriver.findElement(By.id("kw")).sendKeys("软件测试");
        //通过name来定位
        webDriver.findElement(By.name("wd")).sendKeys("软件测试");
        //通过css选择器来定位
        webDriver.findElement(By.xpath("//*[@id=\"kw\"]")).sendKeys("软件测试");
        //通过Xpath来定位
        webDriver.findElement(By.cssSelector("#kw")).sendKeys("软件测试");

2.操作对象

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

click

点击对象

send_keys

在对象上模拟按键输入

clear

清除对象输入的文本内容

submit

提交

text

用于获取元素的文本信息

private static void test1() throws InterruptedException {
        //引入谷歌驱动
        ChromeOptions options = new ChromeOptions();
        //允许所有请求
        options.addArguments("--remote-allow-origins=*");
        WebDriver webDriver = new ChromeDriver(options);
        //启动需要打开的网页
        webDriver.get("https://www.baidu.com");
        Thread time = null;
        sleep(1000);   //为了展示效果设置的等待
        //操作元素
        //输入元素 sendKey
        webDriver.findElement(By.id("kw")).sendKeys("软件测试");
        sleep(3000);
        //清除元素  clear
        webDriver.findElement(By.id("kw")).clear();
        //点击元素  click
        webDriver.findElement(By.id("su")).click();
        //提交元素  submit
        webDriver.findElement(By.id("su")).submit();
        //获取元素文本信息
        String data = webDriver.findElement(By.id("bottom_layer")).getText();
    }

3.添加等待

1)sleep休眠

添加休眠非常简单,我们需要引入time 包,就可以在脚本中自由的添加休眠时间了,这里的休眠指固定休眠;【简单来说就是固定了休眠时间,sleep(2000)就是休眠两秒】

2)隐式等待

隐式地等待并非一个固定的等待时间,当脚本执行到某个元素定位时,如果元素可以定位,则继续执行;如果元素定位不到,则它以轮询的方式不断的判断元素是否被定位到。直到超出设置的时长。

通过添加driver.manage().timeouts().implicitlyWait(5, TimeUnit.SECONDS)的方法去添加隐式等待,可以参考一下官方文档:

等待 | Selenium正在上传…重新上传取消https://www.selenium.dev/zh-cn/documentation/webdriver/waits/​b​​​​​

补充:

//智能等待,3秒
webDriver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);

4.打印信息

getTitle()

用于获得当前页面的title

getCurrentUrl()

用户获得当前页面的URL

getText()

获取页面文本信息

private static void test2() {
        Thread time = null;
        //引入谷歌驱动
        ChromeOptions options = new ChromeOptions();
        //允许所有请求
        options.addArguments("--remote-allow-origins=*");
        WebDriver webDriver = new ChromeDriver(options);
        //启动需要打开的网页
        webDriver.get("https://www.baidu.com/");
        //获取当前页面的url
        String url = webDriver.getCurrentUrl();
        // System.out.println(url);
        //获取当前页面的title
        String title = webDriver.getTitle();
        // System.out.println(title);
        //判断与预期结果是否相同,相同则通过测试,不相同则不通过
        if (url.equals("https://www.baidu.com/")) {
            if (title.equals("百度一下,你就知道")) {
                System.out.println("测试通过");
            } else {
                System.out.println("测试未通过,title错了");
            }

        } else {
            System.out.println("测试未通过,url错了");
        }
    }

运行结果:selenium-java,测试,selenium,测试工具

5.浏览器操作

使用浏览器浏览网页时,浏览器提供了后退和前进按钮,可以方便地在浏览过的网页之间切换,WebDriver也提供了对应的back()和forward()方法来模拟后退和前进按钮。下面通过例子来演示这两个方法的使用。

back()

模拟浏览器后退按钮

forward()

模拟浏览器前进按钮

refresh()

刷新页面(F5)

maximize()

设置浏览器最大化

setSize()

设置浏览器宽高

manage().window().setSize()

设置浏览器的大小。

private static void test3() {
        Thread time = null;
        //引入谷歌驱动
        ChromeOptions options = new ChromeOptions();
        //允许所有请求
        options.addArguments("--remote-allow-origins=*");
        WebDriver webDriver = new ChromeDriver(options);
        //启动需要打开的网页
        webDriver.get("https://www.baidu.com");
        //输入情人节
        webDriver.findElement(By.cssSelector("#kw")).sendKeys("情人节");
        //点击搜索
        webDriver.findElement(By.cssSelector("#su")).click();
        //浏览器刷新
        time.sleep(3000);
        webDriver.navigate().refresh();
        //浏览器后退一步
        time.sleep(3000);        //加个休眠时间方便观察
        webDriver.navigate().back();
        //浏览器前进
        time.sleep(3000);
        webDriver.navigate().forward();
        //浏览器窗口最大化
        webDriver.manage().window().maximize();
        //浏览器窗口按照指定大小来显示
        webDriver.manage().window().setSize(new Dimension(500,500));
        time.sleep(3000);
        //浏览器全屏
        webDriver.manage().window().fullscreen();

6.键盘操作

Keys()类提供了键盘上几乎所有按键的方法。 前面了解到, sendKeys()方法可以用来模拟键盘输入, 除此之 外, 我们还可以用它来输入键盘上的按键, 甚至是组合键, 如 Ctrl+A、 Ctrl+C 等;

以下为常用的键盘操作:

sendKeys(Keys.BACK_SPACE)

回格键(BackSpace

sendKeys(Keys.SPACE)

空格键(Space)

sendKeys(Keys.TAB)

制表键(Tab)

sendKeys(Keys.ESCAPE)

回退键(Esc

sendKeys(Keys.ENTER)

回车键(Enter

sendKeys(Keys.CONTROL,‘a’)

全选(Ctrl+A

sendKeys(Keys.CONTROL,‘c’)

复制(Ctrl+C

sendKeys(Keys.CONTROL,‘x’)

剪切(Ctrl+X

sendKeys(Keys.CONTROL,‘v’)

粘贴(Ctrl+V

private static void test4() throws InterruptedException {
        Thread time = null;
        //引入谷歌驱动
        ChromeOptions options = new ChromeOptions();
        //允许所有请求
        options.addArguments("--remote-allow-origins=*");
        WebDriver webDriver = new ChromeDriver(options);
        //启动需要打开的网页
        webDriver.get("https://www.baidu.com");
        //输入情人节
        webDriver.findElement(By.cssSelector("#kw")).sendKeys("情人节");
        //测试trl+A
        sleep(2000);
        webDriver.findElement(By.cssSelector("#kw")).sendKeys(Keys.CONTROL, "A");
        //测试trl+X
        sleep(2000);
        webDriver.findElement((By.cssSelector("#kw"))).sendKeys(Keys.CONTROL, "X");
        //测试trl+V
        sleep(2000);
        webDriver.findElement((By.cssSelector("#kw"))).sendKeys(Keys.CONTROL, "V");
        //点击
        webDriver.findElement(By.cssSelector("#su")).click();
    }

7.鼠标操作

我们在浏览网页的时候通过鼠标可以进行很多操作,例如鼠标右击、双击、悬停、甚至是鼠标拖动等功能。在WebDriver中,将这些关于鼠标操作的方法封装在ActionChains类提供。 Actions 类提供了鼠标操作的常用方法:

contextClick()

右击

clickAndHold()

鼠标点击并控制

doubleClick()

双击

dragAndDrop()

拖动

release()

释放鼠标

perform()

执行所有Actions中存储的行为

 private static void test5() throws InterruptedException {
        Thread time = null;
        //引入谷歌驱动
        ChromeOptions options = new ChromeOptions();
        //允许所有请求
        options.addArguments("--remote-allow-origins=*");
        WebDriver webDriver = new ChromeDriver(options);
        //启动需要打开的网页
        webDriver.get("https://www.baidu.com");
        //输入情人节
        webDriver.findElement(By.cssSelector("#kw")).sendKeys("情人节");
        //点击百度一下的按钮
        webDriver.findElement(By.cssSelector("#su")).click();
        //找到测试点鼠标右键点击:网页
        WebElement webElement = webDriver.findElement(By.cssSelector("#s_tab > div > b"));
        //鼠标右击
        Actions actions = new Actions(webDriver);
        sleep(3000);
        actions.moveToElement(webElement).contextClick().perform();

    }

8.定位一组元素

定位一组元素,比如多选框

private static void test8() {
        //谷歌驱动
        ChromeOptions options = new ChromeOptions();
        // 允许所有请求
        options.addArguments("--remote-allow-origins=*");
        WebDriver webDriver = new ChromeDriver(options);
//填写要访问的路径,这里是本地的文件
        webDriver.get("http://127.0.0.1:8080/aaa/test.html");
        //定位input标签,并将其扔到List集合中
        List<WebElement> webElements =  webDriver.findElements(By.cssSelector("input"));
        // 如果元素的type值等于checkbox就进行点击
        for (int i = 0; i < webElements.size(); i++) {
            // getAttribute是获取当前页面元素的属性值,type是当前元素的属性
            if(webElements.get(i).getAttribute("type").equals("checkbox")){
                webElements.get(i).click();
            }else {
                ;
            }
        }
    }

9.下拉框处理

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

    private static void test7() {
        Thread time = null;
        //引入谷歌驱动
        ChromeOptions options = new ChromeOptions();
        //允许所有请求
        options.addArguments("--remote-allow-origins=*");
        WebDriver webDriver = new ChromeDriver(options);
        //启动需要打开的网页
        webDriver.get("http://127.0.0.1:8080/blog/test2.html");
        WebElement webElement = webDriver.findElement(By.cssSelector("#ShippingMethod"));
        Select select = new Select(webElement);
        select.selectByIndex(2); //下标从0开始
    }

10.切换窗口句柄

我们在页面操作过程中有时候点击某个链接会弹出新的窗口, 这时就需要主机切换到新打开的窗口上进行操作。WebDriver提供了switchTo().window()方法可以实现在不同的窗口之间切换。

但是:打开一个新窗口人眼可以看到变化,在自动化测试中,自动化脚本无法直接观察出变化,这个时候自动化脚本通过识别浏览器窗口的属性用句柄(handle)来识别。窗口句柄是窗口的唯一标识,可看做窗口的身份证号。

【注意:这是一个在第二个页面的输入框内搜索内容,如果不调用webDriver.getWindowHandle()方法的话,代码就会报错】

private static void test8() {
        Thread time = null;
        //引入谷歌驱动
        ChromeOptions options = new ChromeOptions();
        //允许所有请求
        options.addArguments("--remote-allow-origins=*");
        WebDriver webDriver = new ChromeDriver(options);
        //点击百度的新闻页面
        webDriver.findElement(By.cssSelector("#s-top-left > a:nth-child(1")).click();
        // getWindowHandles获取所以得窗口句柄
        // getWindowHandles获取当前页面的窗口句柄
        //   System.out.println(webDriver.getWindowHandle());
        Set<String> handles = webDriver.getWindowHandles();
        String target_handle = "";
        for (String handle : handles) {
            target_handle = handle;
        }
        webDriver.switchTo().window(target_handle);
        webDriver.findElement(By.cssSelector("#ww")).sendKeys("情人节");
        webDriver.findElement(By.cssSelector("#s_btn_wr")).click();

    }

11.操作截图

自动化用例是由代码编写程序控制网页去执行,因此有时候打印的错误信息并不十分明确。如果在脚本执行出错的时候能对当前窗口截图保存,那么通过图片就可以非常直观地看出出错的原因。 WebDriver提供了截图函数getScreenshotAs()来截取当前窗口;

private static void test9() throws IOException, InterruptedException {
        //谷歌驱动
        ChromeOptions options = new ChromeOptions();
        // 允许所有请求
        options.addArguments("--remote-allow-origins=*");
        WebDriver webDriver = new ChromeDriver(options);
        webDriver.get("https://www.baidu.com/");
        webDriver.findElement(By.cssSelector("#kw")).sendKeys("软件测试");
        webDriver.findElement(By.cssSelector("#su")).click();
        sleep(2000);
        File file = ((TakesScreenshot) webDriver).getScreenshotAs(OutputType.FILE);
        // 放到指定路径下
        Cache FileUtils = null;
        FileUtils.copyFile(file, new File("D://20230527jietu.png"));
    }
}

12.上传文件操作

对于通过input标签实现的上传功能,可以将其看作是一个输入框,即通过sendKeys()指定本地文件路径的方式实现文件上传;【关键是文件要存在且路径正确】

 private static void test10() {
        //谷歌驱动
        ChromeOptions options = new ChromeOptions();
        // 允许所有请求
        options.addArguments("--remote-allow-origins=*");
        WebDriver webDriver = new ChromeDriver(options);
        webDriver.get("http://127.0.0.1:8080/aaa/bbb.html");
        // sendKeys里是上传文件的路径
        webDriver.findElement(By.cssSelector("input")).sendKeys("D:\\Bin\\xnn_res");
    }

四、常见面试题

1.css选择器和xpath选择器你觉得哪个更好?

答:css选择器效率更高

2.quit 和 close的区别

quit 关闭了整个浏览器,close只是关闭了当前的页面;

quit会清空缓存,close则不会;


以上就是本文分享的主要内容,对你有帮助的话,可以点个赞哦~~文章来源地址https://www.toymoban.com/news/detail-614976.html

到了这里,关于【自动化测试】——Selenium (基于java)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【自动化测试】Java+Selenium自动化测试环境搭建

    本主要介绍以Java为基础,搭建Selenium自动化测试环境,并且实现代码编写的过程。 1.Selenium介绍 Selenium 1.0 包含 core、IDE、RC、grid 四部分,selenium 2.0 则是在两位大牛偶遇相互沟通决定把面向对象结构化(OOPP)和便于编写代码的各自思想予以整合后形成的新工具,也就是我们所

    2024年02月11日
    浏览(50)
  • 【自动化测试】基于Selenium + Python的web自动化框架

    Selenium是一个基于浏览器的自动化工具,她提供了一种跨平台、跨浏览器的端到端的web自动化解决方案。Selenium主要包括三部分:Selenium IDE、Selenium WebDriver 和Selenium Grid:  1、Selenium IDE:Firefox的一个扩展,它可以进行录制回放,并可以把录制的操作以多种语言(例如java,p

    2024年02月07日
    浏览(76)
  • 基于Selenium+Python的自动化测试

    (1)了解Selenium+Python环境搭建及配置,能够了解基于Selenium自动化测试的基本原理; (2)能够理解基于Selenium自动登录网页的过程,对软件自动化测试过程的原理有一定的理解,为今后从事web自动化测试奠定基础。 实验环境 : (1)window10操作系统; (2)python开发环境、

    2024年02月03日
    浏览(39)
  • 基于selenium的pyse自动化测试框架

    介绍: pyse基于selenium(webdriver)进行了简单的二次封装,比selenium所提供的方法操作更简洁。 特点: 默认使用CSS定位,同时支持多种定位方法(idnameclasslink_textxpathcss)。 本框架只是对selenium(webdriver)原生方法进行了简单的封装,精简为大约30个方法,这些方法基本能够

    2024年01月18日
    浏览(42)
  • selenium-基于UI的自动化测试框架

      自动化测试是指软件测试的自动化,在预设状态下运行应用程序或者系统,预设条件包括正常和异常,最后评估运行结果,将人为驱动的测试行为转化为机器执行的过程   自动化测试包括UI自动化、接口自动化、单元测试自动化。按照这个金字塔模型来进行自动化测试

    2024年02月05日
    浏览(56)
  • 基于python实现Web自动化测试(selenium)、API自动化测试(requests)&附学习视频

    另一篇文章 :自动化测试框架(pytest)附学习视频 学习视频,学习文档-白月黑羽 说明: 1紧跟着写的不加/,不加空格-表示同一级别信息,加空格表示后代 2.css定位tag,id,class时分别有不同的标识,其他属性都要加[]进行搜索, Xpath所有属性都要都加【】,tag不用 3. css在使用ta

    2024年02月03日
    浏览(102)
  • 【测试开发之路】Java & Selenium自动化

    1、Selenium介绍 ​ 使用前需要下载浏览器对应的Driver,Selenium提供了EdgeDriver和ChromiumDriver两种驱动类。需要安装与本机浏览器版本相同的驱动。 ​ EdgeDriver下载地址:Microsoft Edge WebDriver - Microsoft Edge Developer ​ ChromiumDriver下载地址:CNPM Binaries Mirror (npmmirror.com) 2、导入Maven库 (

    2024年02月12日
    浏览(45)
  • 【教程】JAVA + selenium 进行自动化测试

    自动登录淘宝 获取请求响应数据等 使用到的工具类

    2024年02月11日
    浏览(41)
  • Java + Selenium + Appium自动化测试

    一、启动测试机或者Android模拟器(Genymotion俗称世界上最快的模拟器,可自行百度安装) 二、启动Appium(Appium环境安装可自行百度) 三、安装应用到Genymotion上,如下图我安装一个计算机的小应用,包名为CalcTest.apk 安装步骤:(基于Android SDK已经配置好了环境变量,可自行百

    2024年02月07日
    浏览(41)
  • 保姆级自动化测试教程(Selenium+java)

    自动化测试指软件测试的自动化,在预设状态下运行应用程序或者系统,预设条件包括正常和异常,最后评估运行结果。将人为驱动的测试行为转化为机器执行的过程。 自动化测试包括 UI自动化 , 接口自动化 , 单元测试自动化 。 单元测试 :最大的投入应该在单元测试上

    2024年02月12日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包