美文网首页我爱编程
Python selenium 生成测试报告(HTMLTest

Python selenium 生成测试报告(HTMLTest

作者: 步履不停的Suunny | 来源:发表于2017-12-11 21:48 被阅读0次

    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 生成测试报告(HTMLTest

        本文链接:https://www.haomeiwen.com/subject/hzvwixtx.html