Selenium3+python異常後截圖(screenshot)

前言html

在執行用例過程當中因爲是無人值守的,用例運行報錯的時候,咱們但願能對當前屏幕截圖,留下證據。web

在寫用例的時候,最後一步是斷言,能夠把截圖的動做放在斷言這裏,那麼如何在斷言失敗後截圖呢?框架

 

1、截圖方法測試

1.get_screenshot_as_file(self, filename)ui

--這個方法是獲取當前window的截圖,出現IOError時候返回False,截圖成功返回True。編碼

filename參數是保存文件的路徑。
Usage:
driver.get_screenshot_as_file('/Screenshots/foo.png')url

 

2.get_screenshot_as_base64(self)spa

--這個方法也是獲取屏幕截圖,保存的是base64的編碼格式,在HTML界面輸出截圖的時候,會用到。code

好比,想把截圖放到html測試報告裏。
Usage:
driver.get_screenshot_as_base64()orm

 

3.get_screenshot_as_png(self)
--這個是獲取屏幕截圖,保存的是二進制數據,不多用到.
Usage:
driver.get_screenshot_as_png()

 

2、異常後截圖

1.爲了能拋異常,把定位登陸按鈕的id換了個錯的id。

2.給圖片命名時候加個時間戳,避免同一個文件名稱被覆蓋掉。

3.文件路徑,這裏直接寫的文件名稱,就是跟當前的腳本同一個路徑。若是圖片輸出到其它文件路徑,須要些文件的絕對路徑了。

4.截圖的結果,若是沒截到圖返回False,截圖成功會返回True。

3、selenium實例

1.在unittest框架裏寫用例的時候,咱們但願在斷言失敗的時候,對當前屏幕截圖。

2.若是加try...except捕獲異常後結果,此時全部的測試用例都是經過的了,會影響測試結果。解決辦法其實很簡單,再把異常拋出來就好了。

3.參考代碼:

# coding:utf-8
from selenium import webdriver import time,unittest from selenium.webdriver.support import expected_conditions as EC class Login(unittest.TestCase): def setUp(self): url_login = "https://passport.cnblogs.com/user/signin" self.driver = webdriver.Firefox() self.driver.get(url_login) def test_01(self): '''前面輸入帳號密碼,讓正確運行到assert這一步,斷言故意設置爲False不成功'''
        try: self.driver.find_element_by_id("input1").send_keys(u"李**") self.driver.find_element_by_id("input2").send_keys("xxx") # 登陸id是錯的,定位會拋異常
            self.driver.find_element_by_id("signin").click() # 判斷登陸成功頁面是否有帳號:"李**"
            time.sleep(3) locator = ("id", "lnk_current_user") result = EC.text_to_be_present_in_element(locator,u"李**")(self.driver) self.assertFalse(result) except Exception as msg: print(u"異常緣由%s"%msg) # 圖片名稱能夠加個時間戳
            nowTime = time.strftime("%Y%m%d.%H.%M.%S") self.driver.get_screenshot_as_file('%s.jpg' % nowTime) raise

    def tearDown(self): self.driver.quit() if __name__ == "__main__": unittest.main()

 整理的代碼:

# -*-coding:utf-8 -*-
import os import inspect from datetime import datetime from functools import wraps """ 此模塊用於屏幕截圖 """
# 獲取截截圖保存的路徑
base_path = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) img_base_path = os.path.join(base_path, 'img') # 截圖
def screenshot(driver, case_name, img_base_path): screenshotPath = os.path.join(img_base_path, case_name) time_now = datetime.now().strftime('%Y%m%d%H%M%S') screen_shot_name = "CheckPoint_NG.png" screen_img = screenshotPath + '_' + time_now + '_' + screen_shot_name # screen_img = os.path.join(screenshotPath, screenshotName)
 driver.get_screenshot_as_file(screen_img) return screen_img # 獲得當前類的實例方法名 # 也就是得到用例的名稱
def get_current_function_name(): return inspect.stack()[1][3] # case 斷言失敗截圖裝飾器
def screenshot_about_case(func): # 保持傳入的case的名稱不被裝飾器所改變
 @wraps(func) # t = func
    def get_screenshot_about_case(self, *args, **kwargs): try: func(self, *args, **kwargs) except Exception as e: # 獲取case_name的名稱
            case_name = '{}_{} invoked'.format(self.__class__.__name__, get_current_function_name()) # 截屏的路徑
            screenshotPath = os.path.join(img_base_path, case_name) # 得到如今的時間戳
            time_now = datetime.now().strftime('%Y%m%d%H%M%S') # 名字的一部分
            screen_shot_name = "CheckPoint_NG.png"
            # 組裝圖片須要傳入的路徑和推片名稱
            screen_img = screenshotPath + '_' + time_now + '_' + screen_shot_name # 截圖並保存到相應的名稱的路徑
 self.driver.get_screenshot_as_file(screen_img) raise e return get_screenshot_about_case
相關文章
相關標籤/搜索