TA的每日心情 | 擦汗 3 天前 |
---|
签到天数: 527 天 连续签到: 4 天 [LV.9]测试副司令
|
本示例代码演示了使用Ie浏览器访问百度进行搜索测试。
HTMLTestRunner 从这里下载:
http://tungwaiyip.info/software/HTMLTestRunner_0_8_2/HTMLTestRunner.py
下载后和当前测试脚本放在同一目录。
- # 将以下代码保存到first_webdriver.py中
- #-*- coding:utf-8 -*-
- __author__ = u'苦叶子'
- from selenium import webdriver
- import unittest
- import HTMLTestRunner
- import sys
- from time import sleep
- reload(sys)
- sys.setdefaultencoding("utf-8")
- class BaiduTest(unittest.TestCase):
- """百度首页搜索测试用例"""
- def setUp(self):
- self.driver = webdriver.Ie()
- self.driver.implicitly_wait(30)
- self.base_url = u"http://www.baidu.com"
-
- def test_baidu_search(self):
- driver = self.driver
- print u"开始[case_0001]百度搜索"
- driver.get(self.base_url)
-
- # 验证标题
- self.assertEqual(driver.title, u"百度一下,你就知道")
- driver.find_element_by_id("kw").clear()
- driver.find_element_by_id("kw").send_keys(u"开源优测")
- driver.find_element_by_id("su").click()
- sleep(3)
-
- # 验证搜索结果标题
- self.assertEqual(driver.title, u"开源优测_百度搜索")
-
- def tearDown(self):
- self.driver.quit()
-
- if __name__ == '__main__':
- testunit = unittest.TestSuite()
- testunit.addTest(BaiduTest('test_baidu_search'))
- # 定义报告输出路径
- htmlPath = u"testReport.html"
- fp = file(htmlPath, "wb")
-
- runner = HTMLTestRunner.HTMLTestRunner(stream=fp,
- title=u"百度测试",
- description=u"测试用例结果")
-
- runner.run(testunit)
-
- fp.close()
复制代码 代码解释总体上代码分为五大块 - #-*- coding:utf-8 -*-
- __author__ = u'苦叶子'
复制代码- # 从selenium中导入webdriver模块
- from selenium import webdriver
- # 导入unittest模块,作为用例基类
- import unittest
- # 导入html报告生成模块,用于html格式报告生成
- import HTMLTestRunner
- # 导入sys模块
- import sys
- # 导入sleep模块,用于强制等待
- from time import sleep
复制代码- # 设置当前python运行在utf-8编码下,这样你的中文就不会乱码了
- reload(sys)
- sys.setdefaultencoding("utf-8")
复制代码- # 从unittest.TestCase继承
- class BaiduTest(unittest.TestCase):
- """百度首页搜索测试用例"""
-
- # 用例级初始化函数,自动执行
- def setUp(self):
- # 初始化基于IE浏览器的webdriver实例
- self.driver = webdriver.Ie()
-
- # 给当前webdriver设置全局隐性等待时间,最大30s
- self.driver.implicitly_wait(30)
-
- # 设置首页url
- self.base_url = u"http://www.baidu.com"
-
- def test_baidu_search(self):
- # 简单赋值,这样在本测试中后续就不用每次都写self.driver,
- # 少写几个字符, 都是为了偷懒啊😄
- driver = self.driver
-
- # 在控制台打印输出
- print u"开始[case_0001]百度搜索"
-
- # 启动浏览器,并访问首页
- driver.get(self.base_url)
-
- # 验证标题
- self.assertEqual(driver.title, u"百度一下,你就知道")
-
- # 清理搜索输入框中的数据
- driver.find_element_by_id("kw").clear()
-
- # 在搜索输入框中输入 开源优测
- driver.find_element_by_id("kw").send_keys(u"开源优测")
-
- # 单击 百度一下 按钮
- driver.find_element_by_id("su").click()
-
- # 强制等3s
- sleep(3)
-
- # 验证搜索结果标题
- self.assertEqual(driver.title, u"开源优测_百度搜索")
-
- # 用例级清理函数,自动执行
- def tearDown(self):
- # 退出webdriver,同时关闭当前webdrier session下所有浏览器窗口
- self.driver.quit()
复制代码- # python main函数
- if __name__ == '__main__':
- # 初始化一个用例套件集
- testunit = unittest.TestSuite()
-
- # 往用例套件集新增一个测试
- testunit.addTest(BaiduTest('test_baidu_search'))
-
- # 定义报告输出路径,这里是当前目录
- htmlPath = u"testReport.html"
-
- # 打开测试报告文件
- fp = file(htmlPath, "wb")
-
- # 构建一个HTMLTestReport执行器
- runner = HTMLTestRunner.HTMLTestRunner(stream=fp,
- title=u"百度测试",
- description=u"测试用例结果")
-
- # 运行测试集
- runner.run(testunit)
-
- # 关闭打开的测试报告文件
- fp.close()
复制代码 运行代码使用以下命令运行上述代码
- python first_webdriver.py
复制代码 可以看到:
- 将启动浏览器访问百度首页
- 在百度首页搜索框中输入了 开源优测 单击了 百度一下 按钮 显示出搜索结果
- 闭关了浏览器
- 在当前目录下 生成了testReport.html的测试报告文件
总结最后总结下,要注意的几个关键点:
- 确保要启动的浏览器的驱动已经下载好,具体在哪下载请参见上一章
- 确保下载了HTMLTestRunner模块
- 最好自己把代码一行行敲入一遍,不要直接拷贝运行
|
|