Python 测开28期 - WL - 学习笔记 - 自动化关键数据记录

自动化关键数据记录

  • 什么是关键数据
    • 代码的执行日志
    • 代码执行的截图
    • page source(页面源代码)
  • 记录关键数据的作用
内容 作用
日志 1. 记录代码的执行记录,方便复现场景
2. 可以作为bug一句
截图 1. 断言失败或成功截图
2. 异常截图达到丰富报告的作用
3. 可以作为bug依据
page source 1. 协助排查报错时元素当时是否存在页面上

行为日志记录

  • 日志配置
#文件 log_utils.py

# 日志配置
import logging
# 创建 logger 实例
logger = logging.getLogger('simple_example')
# 设置日志级别
logger.setLevel(logging.DEBUG)
# 流处理器
ch = logging.StreamHandler()
ch.setLevel(logging.DEBUG)
# 日志打印格式
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - $(message)s')
# 添加格式配置
ch.setFormatter(formatter)
# 添加日志配置
logger.addHandler(ch)
  • 脚本日志级别
    • debug 记录步骤信息
    • info 记录关键信息,比如断言等
# test_data_record.py

# 日志与脚本结合
from selenium import webdriver
from selenium.webdriver.common.by import By
from dara_record.log_utils import logger

class TestDataRecord:   
    def setup_class(self):     
        self.driver = webdriver.Chrome()   
        self.driver.implicitly_wait(3)   
    def teardown_class(self):    
        self.driver.quit()  
    def test_log_data_record(self):    
        # 实例化self.driver     
        search_content = "霍格沃兹测试开发"      
        # 打开百度首页        
        self.driver.get("https://www.sogou.com/")       
        logger.debug("打开搜狗首页")     
        # 输入霍格沃兹测试学院        
        self.driver.find_element(By.CSS_SELECTOR, "#query"). \            send_keys(search_content)   
        logger.debug(f"搜索的内容为{search_content}")     
        # 点击搜索 
        self.driver.find_element(By.CSS_SELECTOR, "#stb").click()      
        # 搜索结果   
        search_res = self.driver.find_element(By.CSS_SELECTOR, "em")    
        logger.info(f"搜索结果为{search_res.text}")     
        assert search_content in search_res.text

步骤截图记录

  • save_screenshot(截图路径+名称)
  • 记录关键页面
    • 断言页面
    • 重要的业务场景页面
    • 容易出错的页面
# 调用 save方法截图并保存在当前路径下的images文件夹种
# driver.save_screenshot('./images/searchl.png')
def test_save_screenshot(self):  
   # 实例化self.driver  
   search_content = "霍格沃兹测试开发"  
   # 打开百度首页    
   self.driver.get("https://www.sogou.com/")   
   logger.debug("打开搜狗首页")  
   # 输入霍格沃兹测试学院    
   self.driver.find_element(By.CSS_SELECTOR, "#query"). \        send_keys(search_content)    
   logger.debug(f"搜索的内容为{search_content}")   
   # 点击搜索    
   self.driver.find_element(By.CSS_SELECTOR, "#stb").click()    
   # 搜索结果   
   search_res = self.driver.find_element(By.CSS_SELECTOR, "em")    logger.info(f"搜索结果为{search_res.text}")   
   # 截图记录    
   self.driver.save_screenshot('./images/search_res.png')
   assert search_content in search_res.text

page source 记录

  • 使用 page_source 属性获取页面源码
  • 在调试过程种,如果有找不到元素的错误,可以保存当时的page_source 调式代码
# 在报错行前添加保存 page_source
with open("record.html", "w", encoding="utf-8) as f:
    f.write(self.driver.page_source)