playwright_强大的trace viewer测试追踪功能
我们在做自动化测试过程中,一定会遇到脚本执行失败的情况。由于在脚本执行时不可能工作人员盯着每一个脚本的执行过程,尤其是有时候脚本执行还是在晚上下班时间执行的。这种情况下,我们在分析失败脚本的原因时我们就需要知道在脚本执行失败时的一些信息以方便我们来分析脚本失败的原因,像脚本执行的日志、脚本执行失败时的截图就是我们分析自动化测试脚本失败原因的常用方法。
除了以上两种方式,playwright还提供了更为强大的分析功能Trace Viewer,它可以跟踪脚本执行过程,并可以回放脚本执行的过程。
如何使用这个功能呢?非常简单,只需要在脚本中添加两行代码就可以了,第一行是在创建上下文content对象后,创建page对象前添加:
context.tracing.start(screenshots=True,snapshots=True,sources=True)
第二行是在脚本执行完成后添加
context.tracing.stop(path='trace.zip')
代码添加后,执行完脚本会按照你设置的目录生成一个zip文件,在这个zip文件中记录了整个脚本的执行过程。
实践代码:
# '''
# author: 测试-老姜 交流微信/QQ:349940839
# 欢迎添加微信或QQ,加入学习群共同学习交流。
# QQ交流群号:877498247
# 西安的朋友欢迎当面交流。
# '''
from playwright.sync_api import Playwright, sync_playwright, expect
def run(playwright: Playwright) -> None:
browser = playwright.chromium.launch(headless=False,slow_mo=2000)
context = browser.new_context(base_url="http://127.0.0.1") #设置baseurl
context.tracing.start(screenshots=True,snapshots=True,sources=True) # 设置跟踪
page = context.new_page()
page.goto("/zentao/user-login.html") # 使用相对地址
page.locator("#account").fill("admin")
page.locator("input[name=\"password\"]").click()
page.locator("input[name=\"password\"]").fill("Deshifuzhi01")
page.get_by_role("button", name="登录").click()
page.goto('/zentao/testcase-browse-1.html') # 使用相对地址
context.tracing.stop(path='trace.zip') # 指定跟踪文件保存的路径
page.wait_for_timeout(10000)
# ---------------------
context.close()
browser.close()
with sync_playwright() as playwright:
run(playwright)
查看追踪过程:
1、 使用playwright命令查看
playwright show-trace trace.zip
2、 访问https://trace.playwright.dev/
把zip压缩包拖到网页上,或者通过select files选择就会自动打开追踪日志。
追踪日志打开后,会出现如下页面,使用鼠标在时间轴上滑动就可以查看每个步骤记录下来的页面。