软件测试学习笔记丨Selenium 自动化关键数据日志记录

本文转自测试人社区,原文链接:https://ceshiren.com/t/topic/31692

关键数据

  • 代码的执行日志
  • 代码执行的截图
  • page source(页面源代码)

作用

  • 日志
    1、记录代码的执行过程,方便复现
    2、作为bug依据
  • 截图
    1、断言失败或成功截图
    2、异常截图达到丰富报告的作用
    3、作为bug依据
  • page source
    1、协助排查报错时元素当时是否存在在页面上

行为日志记录

  • 日志配置
class LogConfig:
    def log_config(self):
        """
        1、创建logger实例
        2、设置日志级别
        3、使用流处理器标准输出格式输出
        4、设置日志打印格式
        5、添加格式配置
        6、添加日志配置
        :return:
        """
        # 1、创建logger实例
        self.logger = logging.getLogger('simple_example')
        # 2、设置日志级别
        self.logger.setLevel(logging.DEBUG)
        # 3、使用流处理器输出
        ch = logging.StreamHandler()  # StreamHandler() 用于将日志消息以标准输出流的格式(sys.stdout)输出
        ch.setLevel(logging.DEBUG)
        # 4、设置日志打印格式: 打印日志时间--当前模块名--日志级别--日志信息
        formatter = logging.Formatter \
            ('%(asctime)s-%(name)s-%(levelname)s-%(message)s')
        # 5、添加格式配置
        ch.setFormatter(formatter)
        # 6、添加日志配置
        self.logger.addHandler(ch)
  • 脚本日志级别(debug、info、warning、error、critical)
    1、debug记录执行步骤信息
    2、info记录关键信息,比如断言等
    日志配置结合selenium定位操作,记录自动化关键数据实例:
class TestDataRecord:
    def setup_class(self):
        self.driver = webdriver.Chrome()
        self.driver.get("https://www.sogou.com")
        self.driver.implicitly_wait(3)

    def teardown_class(self):
        self.driver.quit()

    def test_log_data(self):
        """
        1、进入搜狗首页
        2、输入霍格沃茨测试开发,进行搜索操作
        3、获取搜索结果(对应测试用例的实际结果)
        :return:
        """
        search_content = "霍格沃兹测试开发学社"
        self.driver.find_element(By.ID, "query").send_keys(search_content)
        logger.debug(f"搜索的信息为{search_content}")
        self.driver.find_element(By.ID, "stb").click()
        search_res = self.driver.find_element(By.CSS_SELECTOR, "em")
        logger.info(f"实际结果为{search_res.text},预期结果为{search_content}")
        assert search_res.text == search_content

步骤截图记录

  • save_screenshot(截图路径+名称)
  • 记录关键页面(不需要每个步骤都截图)
    1、断言页面
    2、重要的业务场景页面
    3、容易出错的页面
# 调用save方法截图并保存在当前路径下的image文件夹下:
driver.save_screenshot("./images/search1.png")

实例:

def test_screen_data_record(self):
        """
        # 截图记录
        1、进入搜狗首页
        2、输入霍格沃茨测试开发,进行搜索操作
        3、获取搜索结果(对应测试用例的实际结果)
        4、对断言结果截图记录
        :return:
        """
        search_content = "霍格沃兹测试开发学社"
        self.driver.find_element(By.ID, "query").send_keys(search_content)
        logger.debug(f"搜索的信息为{search_content}")
        self.driver.find_element(By.ID, "stb").click()
        search_res = self.driver.find_element(By.CSS_SELECTOR, "em")
        logger.info(f"实际结果为{search_res.text},预期结果为{search_content}")
        # 在断言前截图记录,双重保障
        self.driver.save_screenshot("search_res.png")
        assert search_res.text == search_content

page_source记录(在代码报错处,获取网页源代码,进行错误原因定位)

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

实例:

def test_page_source_data_record(self):
        search_content = "霍格沃兹测试开发学社"
        self.driver.get("https://www.sogou.com/")
        # 获取page_source
        with open("page_source.html", "w", encoding="utf8") as f:
            f.write(self.driver.page_source)
        # 输入霍格沃茨测试开发,进行搜索操作,此处有错误,在报错前添加page_source,获取源码,帮助定位问题
        self.driver.find_element(By.ID, "query1").send_keys(search_content)


推荐学习

【霍格沃兹测试开发】7天软件测试快速入门带你从零基础/转行/小白/就业/测试用例设计实战

【霍格沃兹测试开发】最新版!Web 自动化测试从入门到精通/ 电子商务产品实战/Selenium (上集)

【霍格沃兹测试开发】最新版!Web 自动化测试从入门到精通/ 电子商务产品实战/Selenium (下集)

【霍格沃兹测试开发】明星讲师精心打造最新Python 教程软件测试开发从业者必学(上集)

【霍格沃兹测试开发】明星讲师精心打造最新Python 教程软件测试开发从业者必学(下集)

【霍格沃兹测试开发】精品课合集/ 自动化测试/ 性能测试/ 精准测试/ 测试左移/ 测试右移/ 人工智能测试

【霍格沃兹测试开发】腾讯/ 百度/ 阿里/ 字节测试专家技术沙龙分享合集/ 精准化测试/ 流量回放/Diff

【霍格沃兹测试开发】Pytest 用例结构/ 编写规范 / 免费分享

【霍格沃兹测试开发】JMeter 实时性能监控平台/ 数据分析展示系统Grafana/Docker 安装

【霍格沃兹测试开发】接口自动化测试的场景有哪些?为什么要做接口自动化测试?如何一键生成测试报告?

【霍格沃兹测试开发】面试技巧指导/ 测试开发能力评级/1V1 模拟面试实战/ 冲刺年薪百万!

【霍格沃兹测试开发】腾讯软件测试能力评级标准/ 要评级表格的联系我

【霍格沃兹测试开发】Pytest 与Allure2 一键生成测试报告/ 测试用例断言/ 数据驱动/ 参数化

【霍格沃兹测试开发】App 功能测试实战快速入门/adb 常用命令/adb 压力测试

【霍格沃兹测试开发】阿里/ 百度/ 腾讯/ 滴滴/ 字节/ 一线大厂面试真题讲解,卷完拿高薪Offer !

【霍格沃兹测试开发】App自动化测试零基础快速入门/Appium/自动化用例录制/参数配置

【霍格沃兹测试开发】如何用Postman 做接口测试,从入门到实战/ 接口抓包(最新最全教程)

【霍格沃兹测试开发】6 小时轻松上手功能测试/ 软件测试工作流程/ 测试用例设计/Bug 管理

【霍格沃兹测试开发】零基础小白如何使用Postman ,从零到一做接口自动化测试/ 从零基础到进阶到实战

【霍格沃兹测试开发】建议收藏全国CCF 测试开发大赛Python 接口自动化测试赛前辅导 / 项目实战

更多软件测试开发视频教程点此


软件测试职业发展
在这里插入图片描述
零基础入门
在这里插入图片描述

测试必备编程篇
在这里插入图片描述
自动化测试
在这里插入图片描述
性能测试
在这里插入图片描述
测试管理
在这里插入图片描述
工程效能篇
在这里插入图片描述
面试求职篇

软件测试的面试宝典,内含一线互联网大厂面试真题、面试技巧、软件测试面试简历指导,免费领取!
在这里插入图片描述
在这里插入图片描述

  • 9
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值