-----Web自动化测试之Webdriver(python)--从零到熟练(系列)
经过前三章我们对自动化相关内容的学习,我们了解了什么是自动化测试,测试环境的搭建和WebDriver API的介绍,定位方法及检测点儿设置等相关知识点。从本章开始,我们讲探讨测试用例的编写,以及其相关的知识点。
4.1 第一个测试用例Hello World
几乎所有编程语言的第一个程序就是输出Hello World,那我们也沿袭这个传统,第一个测试用例就是用百度搜索Hello World。
首先我们先写一下这个测试用例的手工测试步骤:
(1)用浏览器打开百度首页。
(2)输入Hello World,然后单击“百度一下”按钮,进行查找。
(3)检测查找到的结果页面,第一项是否包含Hello World。
这是我们手工测试的步骤,如果要转化成自动化测试用例,需要转化成我们需要的脚本语言编写的程序。
4.1.1 Selenium IDE录制
如我们前面讲到的,可以利用Selenium IDE来录制测试步骤,然后添加上检测点,就可以形成一个测试用例。转化成我们需要的脚本语言格式,如python,然后保存文件,放到我们的开发环境下就可以调试运行了。
具体的录制方法如下:
(1)打开火狐浏览器,打开Selenium IDE,在IDE的Base URL中输入要录制的网站地址:http://www.baidu.com。
(2)IDE默认是处于录制状态的,如果没有,单击红色按钮,录制。在火狐浏览器的地址栏中输入http://www.baidu.com,打开百度首页。
(3)输入“Hello World”,单击“百度一下”按钮,进行搜索。
(4)在搜索结果页,右击第一个结果项,如图4.1.1.1所示,选择assert判断项,设置检测点。
(5)单击Selenium IDE的回放按钮,检测录制的测试步骤,如图4.1.1.2所示,不过此时检测点会报错,原因是执行太快,页面没有刷新出来。
(6)为了解决这个问题,我们在检测点前添加一个等待。等待我们要检测的内容出现后,再去执行判断。如图:4.1.1.3所示,回放验证成功。
(7)现在说明我们录制的测试用例没有问题,导出录制的测试用例为python(webdriver)格式的,保存为helloworld.py.如图4.1.1.4所示:
(8)检查导出的代码,Selenium IDE帮我们导出的代码如下:
# -*- coding: utf-8 -*-
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.support.ui import Select
from selenium.common.exceptions import NoSuchElementException
from selenium.common.exceptions import NoAlertPresentException
import unittest, time, re
class Helloworld(unittest.TestCase):
def setUp(self):
self.driver = webdriver.Firefox()
self.driver.implicitly_wait(30)
self.base_url = "http://www.baidu.com/"
self.verificationErrors = []
self.accept_next_alert = True
def test_helloworld(self):
driver = self.driver
driver.get(self.base_url + "/")
driver.find_element_by_id("kw").clear()
driver.find_element_by_id("kw").send_keys("Hello World")
driver.find_element_by_id("su").click()
for i in range(60):
try:
if u"hello world_百度百科" == driver.find_element_by_xpath("//div[@id='content_left']/div/h3/a").text: break
except: pass
time.sleep(1)
else: self.fail("time out")
self.assertEqual(u"hello world_百度百科", driver.find_element_by_link_text(u"hello world_百度百科").text)
def is_element_present(self, how, what):
try: self.driver.find_element(by=how, value=what)
except NoSuchElementException, e: return False
return True
def is_alert_present(self):
try: self.driver.switch_to_alert()
except NoAlertPresentException, e: return False
return True
def close_alert_and_get_its_text(self):
try:
alert = self.driver.switch_to_alert()
alert_text = alert.text
if self.accept_next_alert:
alert.accept()
else:
alert.dismiss()
return alert_text
finally: self.accept_next_alert = True
def tearDown(self):
self.driver.quit()
self.assertEqual([], self.verificationErrors)
if __name__ == "__main__":
unittest.main()
代码讲解:
Ø 最前面是引用Webdriver相关的一些儿函数或方法。
Ø 创建一个测试类Helloworld,类里是具体的一些儿测试方法。
Ø 函数setUp,初始化火狐浏览器,要测试的网站URL等一些儿常用的变量。
Ø 函数test_helloworld() 是我们具体的操作步骤及验证点的检测。
Ø 函数is_element_present():判断元素是否在当前页面显示;is_alert_present():当前页面是否有浮层;close_alert_and_get_its_text():关闭浮层,并返回浮层标题。这几个函数由Selenium IDE自动生成,在本例是没有用到。
Ø 函数tearDown()关闭浏览器,判断是否有错误。
Ø 运行测试用例,这是python的功能,不做详解。
(9)将代码导入到开发环境中。打开Eclipse,新建PyDev工程如:WebAuto。将刚刚保存的helloworld.py文件导入到这个工程中,如图4.1.1.5所示:
图4.1.1.5导入保存的文件
(10) 运行验证刚刚导入的代码,右击这个文件,“Run as”-->”python run”,查看运行结果。程序打开火狐,执行了测试用例,执行完成后关闭浏览器。如图4.1.1.6所示:
(11) 至此,利用Selenium IDE来录制测试用例,并且在开发环境下运行通过。可是我们发现这样录制测试用例还是存在问题的,转化后会有很多用不到的代码存在,而且不符合模块化编程的规范。所以我们还是喜欢自己编写测试用例,录制转化只能当作参考。