《最新出炉》系列初窥篇-Python+Playwright自动化测试-34-处理https 安全问题或者非信任站点-下篇
1.简介
这一篇宏哥主要介绍playwright如何在IE、Chrome和Firefox三个浏览器上处理不信任证书的情况,我们知道,有些网站打开是弹窗,SSL证书不可信任,但是你可以点击高级选项,继续打开不安全的链接。举例来说,想必大家都应该用过前几年的12306网站购票,点击新版购票,是不是会出现如下的界面。宏哥又找了一个https的页面,不过现在这种网站很少了,主要原因就是大家越来越觉得安全的重要性,想要找到这么个网站可是不容易,费了好久,一个客户的VPN刚好是这种情况,如下图所示:
2.三种浏览器如何处理不受信任的证书
在selenium三种浏览器访问网页,弹出证书不信任,需要点击下信任继续访问才行,多为访问https的网页。那么我们在做自动化测试的时候,如何跳过这一步骤,直接访问到我们需要的页面了,这个就是宏哥主要分享和讲解的如何在三大浏览器跳过这一步骤。因此宏哥在playwright中也觉得类似差不多,但是代码写完后,宏哥直接傻眼了,完全不一样啊!!!playwright直接都没有访问到那个安全提示的页面,就报错了:playwright._impl._api_types.Error: net::ERR_CERT_AUTHORITY_INVALID at。
3.解决方案
1.宏哥网上查了有关资料说是有关证书安全或则信任的错误,那么遇到这种我们怎么处理呢???首先确定的之前那种定位到【详细信息】,点击,然后再定位到【转到此网页(不推荐)】点击的方法不能用了,因为根本就没有访问到这个页面,怎么定位点击。
2.既然第一种不行,那就另辟蹊径,除了上一篇中提到的这种方法:playwright 设置 ignore_https_errors 参数忽略 SSL 错误 。后来随着学习和了解还有一种方法:结合 pytest-playwright 用例插件。
3.1结合 pytest-playwright 用例插件
pytest-playwright
插件写自动化用例时,在conftest.py 中加入context 上下文启动参数,语法如下:
# conftest.py import pytest @pytest.fixture(scope="session") def browser_context_args(browser_context_args): return { **browser_context_args, "ignore_https_errors": True, } @pytest.fixture(scope="session") def browser_context_args(browser_context_args): return { **browser_context_args, "viewport": { "width": 1920, "height": 1080, } }
pytest-playwright插件完美的继承了pytest 用例框架和playwright基础使用的封装,基本能满足工作中的常规需求了,不需要我们再做额外的插件开发。
3.1.1pytest-playwright 环境准备
Playwright 建议使用官方的 pytest-playwright 插件来编写端到端测试。它提供上下文隔离,开箱即用地在多个浏览器配置上运行。或者,您可以使用该库使用您喜欢的测试运行程序手动编写测试基础设施。Pytest 插件使用 Playwright 的同步版本,还有一个可通过库访问的异步版本。
开始安装 Playwright 并运行示例测试以查看它的实际效果。
3.1.2安装pytest-playwright
在Docs命令窗口输入如下命令:
pip install pytest-playwright
4.项目实战
4.1代码设计
4.2参考代码
# coding=utf-8🔥 # 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行 # 2.注释:包括记录创建时间,创建人,项目名称。 ''' Created on 2023-11-18 @author: 北京-宏哥 公众号:北京宏哥 Project: 《最新出炉》系列初窥篇-Python+Playwright自动化测试-34-处理https 安全问题或者非信任站点-下篇 ''' # 3.导入模块 import pytest from playwright.sync_api import sync_playwright def test_example(): with sync_playwright() as p: browser = p.chromium.launch(headless=False) page = browser.new_context( ignore_https_errors=True, viewport={ "width": 1920, "height": 1040, } ) page = page.new_page() page.goto("https://1**.2*#.12*.9&:8899") assert page.title() == "欢迎访问" page.wait_for_timeout(3000) browser.close() if __name__ == '__main__': pytest.main(["-v", "test_example.py"])
4.3运行代码
1.运行代码,右键Run'Test',控制台输出,如下图所示:
2.运行代码后电脑端的浏览器的动作。如下图所示:
5.小结
今天主要讲解和分享的是如何利用playwright中的pytest-playwright如何处理https错误的问题。
到此遇到了类似的问题就可以参考宏哥的方法就行解决了,宏哥这里仅仅讲解和分享了一下Chrome浏览器,其他的浏览器类似的处理方法,不过宏哥没有试过,不一定能成功,有兴趣的童鞋或者小伙伴们可以尝试一下。后期宏哥会专门对pytest-playwright进行详细讲解的。
好了,时间不早了,今天就分享到这里,感谢大家耐心的阅读!!!
6.扩展
6.1codegen录制用例
有的小伙伴或者童鞋们很早之前就问到了录制遇到https报错,怎么办呢?今天就在这里提一下,后期宏哥会专门讲解录制,以及遇到https的解决方法:录制用例时,启动命令添加--ignore-https-errors。语法如下:
playwright codegen --ignore-https-errors https://example.com
感谢您花时间阅读此篇文章,如果您觉得这篇文章你学到了东西也是为了犒劳下博主的码字不易不妨打赏一下吧,让博主能喝上一杯咖啡,在此谢过了!
如果您觉得阅读本文对您有帮助,请点一下左下角“推荐”按钮,您的
本文版权归作者和博客园共有,来源网址:https://www.cnblogs.com/du-hong 欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利!
公众号(关注宏哥)                                                                                 客服微信