前言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