一、行为日志
- 使用 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
@pytest.fixture(scope="session", autouse=True)
def manage_logs(request):
"""Set log file name same as test name"""
now = time.strftime("%Y-%m-%d %H-%M-%S")
log_name = 'output/log/' + now + '.logs'
request.config.pluginmanager.get_plugin("logging-plugin") \
.set_log_path(log_name)
二、截图
方法名 |
描述 |
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"