当前位置:   article > 正文

playwright自动化项目搭建

playwright自动化项目搭建

2024软件测试面试刷题,这个小程序(永久刷题),靠它快速找到工作了!(刷题APP的天花板)【持续更新最新版】-CSDN博客

具备功能

关键技术:

  • pylaywright测试库
  • pytest单元测试框架
  • pytest-playwright插件

非关键技术:

  • pytest-html插件
  • pytest-rerunfailures插件
  • seldom 测试框架

实现功能:

  • 元素定位与操作分离
  • 失败自动截图并保存到HTML报告
  • 失败重跑
  • 可配置不同的浏览器执行
  • 可配置headless/headful 模式
  • 实现参数化读取数据文件

一个自动化具备的基本功能差不多就这些了。其实主要是使用了一堆框架和插件,主要是整合能力。

使用方式

  • 安装依赖
$ pip install -r requirements.txt

注:安装requirements.txt指定依赖库的版本,这是经过测试的,有时候新的版本可会有错。

  • 配置

在 config.py 文件配置

  1. class RunConfig:
  2. """
  3. 运行测试配置
  4. """
  5. # 运行测试用例的目录或文件
  6. cases_path = "./test_dir/test_parametrize.py"
  7. # 配置浏览器驱动类型(chromium, firefox, webkit)。
  8. browser = "chromium"
  9. # 运行模式(headless, headful)
  10. mode = "headful"
  11. # 配置运行的 URL
  12. url = "https://www.baidu.com"
  13. # 失败重跑次数
  14. rerun = "0"
  15. # 当达到最大失败数,停止执行
  16. max_fail = "5"
  • 运行

运行测试

$ python run.py

设计细节

  • 关于page object设计模式

page object是自动化测试最常用的设计模式。

但 playwright 中的只提供了操作方法,元素定位测试数据都只是参数。

  1. # 输入
  2. page.type('#kw', "playwright")
  3. # 点击
  4. page.click('#su')

我们依然,可以将元素定位单独封装一层。

  1. class BaiduElem:
  2. search_input = "#kw" # 搜索框
  3. search_button = "#su" # 搜索按钮
  4. settings = "#s-usersetting-top" # 设置
  5. search_setting = "#s-user-setting-menu > div > a.setpref" # 搜索设置
  6. save_setting = 'text="保存设置"' # 保存设置

在测试用例中的使用

  1. from element.baidu_element import BaiduElem
  2. from playwright.sync_api import Page
  3. def test_baidu_search(page: Page, base_url):
  4. """
  5. """
  6. page.goto(base_url)
  7. page.type(BaiduElem.search_input, text="playwright")
  8. page.click(BaiduElem.search_button)
  9. sleep(2)
  10. assert page.title() == "playwright_百度搜索"

这肯定不是什么好的设计。用例层写起来会比较啰嗦, 最好可以page.elem.type("playwright") 的语法实现,这就需要在playwright的基础上再封装一套API, 看playwright 源码还是有些复杂的,主要是用了很多就异步,成本比较大,暂时先这么用。

  • 关于自动截图

自动截图需要 pytest/pytest-html 和 playwright 配合完成, pytest/pytest-html 判断用例实现,并把图片插入到报告中。 playwright 实现截图动作。

  1. @pytest.mark.hookwrapper
  2. def pytest_runtest_makereport(item):
  3. """
  4. 用于向测试用例中添加用例的开始时间、内部注释,和失败截图等.
  5. :param item:
  6. """
  7. pytest_html = item.config.pluginmanager.getplugin('html')
  8. outcome = yield
  9. report = outcome.get_result()
  10. report.description = description_html(item.function.__doc__)
  11. extra = getattr(report, 'extra', [])
  12. page = item.funcargs["page"]
  13. if report.when == 'call':
  14. xfail = hasattr(report, 'wasxfail')
  15. if (report.skipped and xfail) or (report.failed and not xfail):
  16. case_path = report.nodeid.replace("::", "_") + ".png"
  17. if "[" in case_path:
  18. case_name = case_path.split("-")[0] + "].png"
  19. else:
  20. case_name = case_path
  21. capture_screenshots(case_name, page)
  22. img_path = "image/" + case_name.split("/")[-1]
  23. if img_path:
  24. html = '<div><img src="%s" alt="screenshot" style="width:304px;height:228px;" ' \
  25. 'onclick="window.open(this.src)" align="right"/></div>' % img_path
  26. extra.append(pytest_html.extras.html(html))
  27. report.extra = extra
  28. def capture_screenshots(case_name, page):
  29. """
  30. 配置用例失败截图路径
  31. :param case_name: 用例名
  32. :return:
  33. """
  34. global driver
  35. file_name = case_name.split("/")[-1]
  36. if RunConfig.NEW_REPORT is None:
  37. raise NameError('没有初始化测试报告目录')
  38. else:
  39. image_dir = os.path.join(RunConfig.NEW_REPORT, "image", file_name)
  40. page.screenshot(path=image_dir)

通过page = item.funcargs["page"] 拿到playwright的驱动,截图判断逻辑有点复杂,不过我已经实现了。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你! 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/320317
推荐阅读
相关标签
  

闽ICP备14008679号