Python selenium 生成测试报告(HTMLTestRunner)

Python selenium

生成测试报告(HTMLTestRunner)

  1. 下载HTMLTestRunner.py文件,通过此文件生成测试报告

  2. 将文件放到...\Python27\Lib目录下(windows)

  3. 可以通过dir(HTMLTestRunner)查看包含哪些方法

    >>> import HTMLTestRunner
    >>> dir(HTMLTestRunner)
    ['HTMLTestRunner', 'OutputRedirector', 'StringIO', 'Template_mixin', 'TestProgram', 'TestResult', 
    '_TestResult', '__author__', '__builtins__', '__doc__', '__file__', '__name__', '__package__', 
    '__version__', 'datetime', 'main', 'saxutils', 'stderr_redirector', 'stdout_redirector', 'sys', 'time', 
    'unittest']
    
  4. 下面可以在用例中添加可以生成报告的代码

     #coding:utf-8
     from selenium import webdriver
     from selenium.webdriver.support.ui import Select
     import unittest, time
     import HTMLTestRunner
    
     class Baidu(unittest.TestCase):
         def setUp(self):  # 用于设置初始化的部分
             self.driver = webdriver.Firefox()
             self.driver.implicitly_wait(30) # 隐性等待,最长等30秒
             self.base_url = "http://www.baidu.com"
             self.verificationErrors = []    # 脚本运行时,错误的信息将被打印到这个列表中。
             self.accept_next_alert = True  # 是否继续接受下一个警告
     
         def test_baidu_serach(self):
             driver = self.driver
             driver.get(self.base_url + "/")
             driver.find_element_by_id("kw").send_keys("Selenium webdriver")
             driver.find_element_by_id("su").click()
             time.sleep(2)
             driver.close()
     
     
         def test_baidu_set(self):
             driver = self.driver
             driver.get(self.base_url + "/gaoji/preferences.html")  # 进入搜索设置页
     
             Select(driver.find_element_by_id("nr")).select_by_visible_text(u"每页显示10条")
             time.sleep(2)
             driver.find_element_by_id("save").click()
             time.sleep(2)
             # driver.switch_to_alert().accept()  # 此方法即将弃用。
             driver.switch_to.alert.accept()  
             time.sleep(2)
             # 保存百度的设置时会会弹出一个确定按钮;我们并没按照常规的方法去定位弹窗上的“确定”按钮,而是使用switch_to.alert.accept() 
             
         def tearDown(self):
             self.driver.quit()
             self.assertEqual([], self.verificationErrors)
     
     if __name__ == "__main__":
         testunit = unittest.TestSuite()  # 定义一个单元测试容器
         testunit.addTest(Baidu("test_baidu_serach"))  # 将测试用例加入到测试容器中
         testunit.addTest(Baidu("test_baidu_set"))
         filename = 'D:\\result.html'  # 定义个报告存放路径,支持相对路径。
         fp = file(filename, 'wb')
         runner = HTMLTestRunner.HTMLTestRunner(
             stream=fp,
             title='Report_title',
             description='Report_description')
         runner.run(testunit)  # 自动进行测试
     
     注意,运行的时候,需要使用python run,不能以unittest运行,否则不能生成测试报告。 原因是 pycharm的Run unittest会直接运行用例,不走下面的man函数。 
    

补充

  1. Python selenium 三种等待方式详解

    1. 强制等待:简单粗暴, 这种叫强制等待,不管你浏览器是否加载完了,程序都得等待xx秒,xx秒一到,继续执行下面的代码.
      作为调试很有用,有时候也可以在代码里这样等待,不过不建议总用这种等待方式,太死板,严重影响程序执行速度。

      sleep(3) # 强制等待3秒再执行下一步
      
    2. 隐形等待: 隐形等待是设置了一个最长等待时间,如果在规定时间内网页加载完成,则执行下一步,否则一直等到时间截止,然后执行下一 步。 隐性等待对整个driver的周期都起作用,所以只要设置一次即可

      driver.implicitly_wait(30) # 隐性等待,最长等30秒
      
    3. 显性等待:WebDriverWait,配合该类的until()和until_not()方法,就能够根据判断条件而进行灵活地等待了。它主要的意思就是:程 序每隔xx秒看一眼,如果条件成立了,则执行下一步,否则继续等待,直到超过设置的最长时间,然后抛出TimeoutException。

      WebDriverWait(driver, 20, 0.5).until(EC.presence_of_element_located(locator))

你可能感兴趣的:(Python selenium 生成测试报告(HTMLTestRunner))