最近系统前端组件做了更新,我就把之前做的web自动化的代码做了一些修改,顺便优化了下用例,只保留少量的测试用例了,大头还是在接口自动化上。然后发现关于pytest的还有一个点应该比较常用,这里再介绍一下。
相信有的同学在使用python的unittest框架做web自动化测试的时候会遇到一个问题,需要在setUp方法里去定义浏览器驱动,为了执行case之前打开浏览器。如果在执行很多case的时候呢,打开浏览器浪费的时间还是挺多的,当然了,你可以一个模块打开一次浏览器,不过仍然不是我们最终想要的,执行全部测试,只需要打开一次浏览器,这才是我们想要的。
一、使用unittest的传统方式
这里就是使用unittest框架,执行之前DemoCase类下的用例前打开浏览器。
class DemoCase(unittest.TestCase):
def setUp(self): #每个用例执行之前
print('before test')
self.driver = webdriver.Chrome()
def test_demo1(self):
xxxx
def test_demo2(self):
xxxx
def tearDown(self): #每个用例执行之前
self.driver.quit()
if __name__ == '__main__':
unittest.main()
二、使用pytest实现打开一次浏览器
这里要用到conftest.py跟fixture了,在之前的文章里已经讲过。
还有一个点就是web自动化的原理,其实就是我们的代码向被测试的浏览器发送了一个http请求,然后浏览器接受请求,执行相应操作,并在Response中返回执行状态、返回值等信息。所以当你启动一次浏览器的时候就是产生了一次session,下面来实现以下就好了。
原理也很简单,在你case所在目录的上层创建conftest.py文件,不放心的可以放在项目根目录下。然后在conftest.py文件里定义一个全局的浏览器驱动,利用pytest的fixture特性,设置这个驱动的范围在整个session里,几行代码就可以了。
#conftest.py
driver = None
@pytest.fixture(scope='session', autouse=True)
def browser():
global driver
if driver is None:
driver = webdriver.Chrome()#GUI界面运行
driver.maximize_window()
return driver #返回驱动
使用的时候,在需要启动浏览器进行页面操作的地方,传入驱动就好了。比如下面的这个登录操作
#test_demo.py
def test_login_failed(browser, username, password, res):
'''测试非法登录'''
LP = LoginPage(browser)
error_msg = LP.login_failed_and_return_error_msg(username, password)
assert error_msg == res
这是建立在使用page object设计模式上的,对应的,LoginPage里用对应的方法封装页面操作。
是不是很简单,赶快去试试吧,欢迎留言交流!