今天开始批量执行用例~,场景是这样的:
工作中我们可能有多个模块文件(.py)这些文件根据不同的业务类型或功能,测试案例分布在不同的模块文件下。前面的小示例中,我们的测试用例都是在一个文件中,直接运行的测试套件~,开发阶段或者调试阶段这样做是没毛病的,但是如果是测试运行阶段,我们不可能这个模块文件下的用例执行完毕后,切换另一个模块中的用例继续执行。所以我们需要用的批量执行多个模块文件的测试用例。
首先第一个用例模块的案例是这样的~
1 import unittest #导入unittest库
2 from selenium import webdriver #导入自动化测试selenium中的webdriver
3
4 class baidu_test_1(unittest.TestCase): #写一个baidu_test_1 类,继承unittest中的TestCase类
5
6 @classmethod #方便我们直接调用,不需要实例化类的对象直接调用
7 def setUp(cls): #所有案例执行前,都先执行该方法,初始化
8 cls.driver = webdriver.Chrome() #实例化一个webdriver对象
9 cls.driver.maximize_window() #最大化浏览器窗口
10 cls.driver.implicitly_wait(15) #页面加载慢的情况,我们设置等待时长15秒
11 cls.driver.get(r'http://www.baidu.com') #打开百度的首页
12
13 @classmethod
14 def tearDown(cls): #所有案例执行后,执行该方法
15 cls.driver.quit() #关闭浏览器
16
17 '''测试用例'''
18 def test_baidu_lianjie(self): #百度链接测试的用例
19 '''百度首页:测试新闻链接,跳转后的链接地址是否正确'''
20 self.driver.find_element_by_link_text('新闻').click() #点击新闻链接后,获取新闻链接:self.driver.current_url
21 self.assertEqual(self.driver.current_url,'http://news.baidu.com/') #用获取到的链接,和实际链接做对比,看是不是相等
22
23 '''if __name__ == '__main__'的意思是:当.py文件被直接运行时,if __name__ == '__main__'之下的代码块将被运行;
24 当.py文件以模块形式被导入时,if __name__ == '__main__'之下的代码块不被运行。'''
25 if __name__ == '__main__':
26 unittest.main(verbosity=2)
接下来是第二个用例模块的代码:
1 import unittest
2 from selenium import webdriver
3
4 class baidu_test_2(unittest.TestCase):
5 @classmethod
6 def setUp(cls):
7 cls.driver=webdriver.Chrome()
8 cls.driver.maximize_window()
9 cls.driver.implicitly_wait(15)
10 cls.driver.get(r'http://www.baidu.com')
11
12 @classmethod
13 def tearDown(cls):
14 cls.driver.quit()
15
16 def test_baidu_enabled(self):
17 so=self.driver.find_element_by_id('kw') #检查元素是否可编辑用is_enabled(),可以编辑返回的是True
18 self.assertTrue(so.is_enabled()) #如果返回的是True,那么就是真真为真~通过
19
20 def test_baidu_sousuo(self):
21 so = self.driver.find_element_by_id('kw')
22 so.send_keys('你好中国') #上面的代码选择了输入框,这是输入:send_keys()
23 self.driver.find_element_by_id('su').click() #该方法是模拟点击操作click()
24 print(so.get_attribute('value')) #根据属性获取表单中的值get_attribute('value')
25 self.assertEqual(so.get_attribute('value'),'你好中国') #我们用获取到的值,和我们预期的值做对比,看是否相等
26
27 if __name__ == '__main__':
28 unittest.main(verbosity=2)
注意:测试模块的名称,前面需要统一,看图:两个测试用例模块文件的名字前面都是test_ 开头
接下来就是最后一个模块文件的代码,批量执行用例模块中的代码:
1 import unittest #导入unittest
2 import os #导入前面学习的os库,方便获取文件路径
3
4 def allTests():
5 suite=unittest.TestLoader().discover( #实例化测试套件
6 start_dir=os.path.dirname(__file__), #start_dir=该参数是discover()方法中的,后面的参数是需要批量执行的用例模块路径
7 pattern='test_*.py', #pattern=该参数是discover()方法中的,后面的参数是所有需要执行的用例前面是test_,后半部分用*号代替的.py文件
8 top_level_dir=None) #top_level_dir=该参数是discover()方法中的,固定格式:top_level_dir=None
9 return suite #记住返回测试套件
10
11 def run(): #运行
12 unittest.TextTestRunner(verbosity=2).run(allTests()) #测试报告
13
14 if __name__ == '__main__':
15 run()
批量执行就是这样的~~~~
总结:
1、 #检查元素是否可编辑用is_enabled(),可以编辑返回的是True,否则是Flase
2、在编辑框中输入内容用:send_keys()
3、点击按钮的操作可以用:click()
4、根据属性获取表单中的值get_attribute('value') 比如搜索中的内容
5、获取当前页面的url链接地址: driver.current_url 来判断我们跳转的页面是否正确
6、批量执行用例用到的unitest库中的TestLoader()类,该类中的discover(start_dir, pattern=’test*.py’, top_level_dir=None)方法
discover中可以看出有三个参数:以下是百度给大家的轮子~~~自行学习
start_dir :要测试的模块名或测试用例目录。
pattern='test*.py' :表示用例文件名的匹配原则。星号“*”表示任意多个字符。(test*.py是以test开头)
top_level_dir=None:测试模块的顶层目录。如果没顶层目录(也就是说测试用例不是放在多级目录中),默认为 None。
-------------来自自学的总结,希望对大家有帮助,不会的朋友可以留言,一起进步~~~~~秋天来了,注意季节转换,容易生病~~~~~~贴秋膘