23.自动化关键数据记录

发布时间 2023-12-23 09:57:36作者: 想要暴富的小男孩

目录

  • 行为日志
  • 截图
  • 页面源码

行为日志

  • 使用 python 自带的 logging 模块
  • 使用 pytest.ini 配置日志开关与格式
  • 参考链接
[pytest]
;日志开关 true false
log_cli = true
;日志级别
log_cli_level = info
;打印详细日志,相当于命令行加 -vs
addopts = --capture=no
;日志格式
log_cli_format = %(asctime)s [%(levelname)s] %(message)s\
         (%(filename)s:%(lineno)s)
;日志时间格式
log_cli_date_format = %Y-%m-%d %H:%M:%S
;日志文件位置
log_file = ./log/test.log
;日志文件等级
log_file_level = info
;日志文件格式
log_file_format = %(asctime)s [%(levelname)s] %(message)s \
        (%(filename)s:%(lineno)s)
;日志文件日期格式
log_file_date_format = %Y-%m-%d %H:%M:%S

截图

 
方法名描述
get_screenshot_as_file(filename) 保存图片为.png 格式,filename 图片路径
save_screenshot(filename) 保存图片为.png 格式,filename 图片路径
get_screenshot_as_png() 保存图片为二进制格式
get_screenshot_as_base64() 将图片保存为 base64 格式。通常用在 html 里添加截图
   

获取页面源码

  • 通过获取页面源码,分析页面的 dom 结构
  • driver.page_source

示例代码

def test_search(self):
        '''使用 xpath 定位'''
        logging.info("搜索用例")
        element = self.driver.find_element(MobileBy.XPATH,"//*[@resource-id='com.xueqiu.android:id/tv_search']")
        search_enabled = element.is_enabled()

        logging.info(f"搜索框的文本:{element.text},搜索框的坐标:{element.location},搜索框的size:{element.size}")

        if search_enabled == True:
            logging.info("点击搜索框")
            element.click()
            logging.info(f"输入搜索内容:alibaba")
            self.driver.find_element(MobileBy.XPATH,
                                     "//*[@resource-id='com.xueqiu.android:id/search_input_text']").\
                send_keys("alibaba")

            alibaba_element = self.driver.find_element(MobileBy.XPATH, "//*[@text='阿里巴巴']")

            # alibaba_element.is_displayed()
            displayed = alibaba_element.get_attribute("displayed")
            logging.info(f"是否可见:{displayed}")
            self.driver.save_screenshot("./image/search_result.png")
            assert displayed == "true"