AirtestProject Selenium 快速上手实战 | 上篇

fishfish-yu · 2020年02月19日 · 1834 次阅读

此文章来源于项目官方公众号:“AirtestProject”
版权声明:允许转载,但转载必须保留原链接;请勿用作商业或者非法用途

前言

Selenium 是一个用于 Web 应用程序的自动化测试工具。它直接运行在浏览器中,可以模拟用户在浏览器上面的行为操作。

在 AirtestIDE 中,开发者也给我们提供了使用 Selenium 的窗口。不过使用的框架是 Airtest-Selenium 框架。Airtest-Selenium 是对 selenium 的 python 库做的一层封装,它添加了部分图像识别的接口,也可以生成网页版测试报告。

本文将借助 IDE 上的 Selenium 窗口,来给大家讲解在浏览器上进行自动化测试的实战。

IDE 中的 Selenium 窗口

在 AirtestIDE 中调出 Selenium 的窗口

默认情况下,IDE 没有并显示 Selenium 的窗口,所以我们需要在 IDE 顶部的窗口菜单下,把Selenium Window勾选上,勾选之后 Selenium 的窗口才会显示在 IDE 界面的左侧。

插入初始代码的快捷按钮

Selenium Window 给我们提供了一些常用的按钮,比如点击窗口下类似地球的按钮,会自动帮我们在脚本编辑窗口插入一些初始化代码:

插入代码之前,我们需要在脚本窗口弹出的黄色提供框中,选择 Yes 允许插入代码:

这样,脚本编辑窗就会自动插入如下代码:

# 引入selenium的webdriver模块
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from airtest_selenium.proxy import WebChrome

#创建一个实例,代码运行到这里,会打开一个chrome浏览器
driver = WebChrome()
driver.implicitly_wait(20)

需要注意的是,如果是首次使用这个按钮,IDE 会弹窗提示需要设置谷歌浏览器的路径:

这时我们就需要先到选项--设置中,找到 Selenium 那部分内容,然后把 chrome 的路径设置好,才能正常插入上述代码。

Selenium 的常用方法

打开指定网址

我们以打开百度首页为例子:

driver.get("https://www.baidu.com/")

driver.get() 方法会在浏览器中打开一个指定的网址,给它传入网址地址即可。

最大化窗口
driver.maximize_window()
关闭窗口/浏览器
# 关闭当前窗口,如果浏览器此时只有1个窗口,浏览器也会被关闭
driver.close()

# 退出驱动关闭所有窗口
driver.quit()

Airtest-Selenium 简介

上文我们提到 Airtest-Selenium 是基于 Selenium 语法的,但是 Airtest 的开发者们还另外封装了如下方法:

图像识别接口

Airtest-Selenium 对图像识别的封装有两个接口,图像识别点击和图像识别断言:

①点击 Selenium Window 下方的 airtest_touch 按钮

在浏览器页面上截取你想要点击位置的图片,双击完成截图,脚本编辑窗口会自动生成 1 条图像识别点击的脚本

driver.airtest_touch(Template(r"tpl1582031994893.png", record_pos=(8.99, 5.23), resolution=(100, 100)))

②点击 Selenium Window 下方的 assert_template 按钮

在浏览器页面上截取你想要进行断言的图片,双击完成截图,脚本编辑窗口会自动生成 1 条图像识别断言脚本

driver.assert_template(Template(r"tpl1582032716811.png", record_pos=(0.51, 1.315), resolution=(100, 100)), "成功打开airlab官网")

关于 Selenium 更多的断言实例,详看我们之前的推文 “测试同学都应该知道的断言知识...” 。

值得注意的是,这两个接口是基于 Airtest 框架的图像识别封装,如果图像脚本运行时在网页中找不到对应图像,会抛出Target not found on screen的异常。

多标签页录制

selenium 提供了切换标签页的接口。

driver.switch_to.window(driver.window_handles[number])

这个语句执行后,可以切换到第 number 个打开的标签页。但是对于用户来说,这个接口不是那么好理解与调用,因为这样需要记住标签打开的顺序。

而大部分时候,切换标签页的操作一般都出现在:打开新窗口、关闭标签页这两种情况下。因此,Airtset-Selenium 封装了两个接口:

driver.switch_to_new_tab()
driver.switch_to_previous_tab()

在这个接口内部,Airtest-Selenium 维护了标签页的组织结构。用户只需在打开新标签页时,调用switch_to_new_tab

另外在结束当前标签页时,回到上一个标签页时,调用switch_to_previous_tab()即可,不再需要去考虑当前是第几个这样之类的问题。

生成报告

被 Airtest-Selenium 封装的接口,运行过后都会生成对应的报告,在 AirtestIDE 中可以直接点击生成报告按钮,即可查看对应的报告内容。

小结

我们以 1 个小的实战案例来总结今天讲述的内容:

# -*- encoding=utf8 -*-
__author__ = "19617"

from airtest.core.api import *

from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from airtest_selenium.proxy import WebChrome
driver = WebChrome()
driver.implicitly_wait(20)

driver.get("https://airlab-gl.163.com/b2b")

driver.maximize_window()

driver.assert_template(Template(r"tpl1582032716811.png", record_pos=(0.51, 1.315), resolution=(100, 100)), "成功打开airlab官网")

driver.airtest_touch(Template(r"tpl1582034527805.png", record_pos=(8.975, 5.765), resolution=(100, 100)))


driver.switch_to_new_tab()

driver.switch_to_previous_tab()

driver.quit()

预告

Selenium 快速上手实战 | 下篇 将给大家讲述如下内容:

① chrome 调试工具实战

② Selenium 元素定位实战

③ Selenium 与页面的交互

关注下方公众号,可以查看更多往期教程;回复 “交流群” 即可加入我们的测试开发官方交流群

暂无回复。
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册