• 《最新出炉》系列初窥篇-Python+Playwright自动化测试-16-处理模态对话框弹窗


    1.简介

    我们在日常工作中,会经常遇到弹出警告框的问题,弹框无法绕过,必须处理才可以执行后续的测试,所以弹框处理也是我们必须掌握的一个知识。宏哥在java+selenium系列文章中介绍过这部分内容。那么,playwright对于弹框的处理是怎样的?是否比selenium更加简单呢?下面我们就来介绍一下playwright对于弹框的处理。

    2.弹框分类

    弹框通常分为3种,分别为alert,confirm,promot。

    • alert弹框:只有信息和确定按键
    • confirm弹框:在alert弹窗基础上增加了取消按钮
    • prompt弹框:在confirm的基础上增加了可输入文本内容的功能

    3.dialog 弹窗

    3.1dialog属性和方法

    accept()当对话框被接收时返回。

    dialog.accept()
    dialog.accept(**kwargs)

    参数 prompt_text(可选), 要在提示中输入的文本。如果对话框 type 没有提示,则不会产生任何影响.

    default_value, 如果对话框是提示的,则返回默认提示值。否则,返回空字符串。

    dialog.default_value

    dismiss 关闭对话框

    dialog.dismiss()

    message 获取对话框中显示的消息

    dialog.message

    type返回对话框的类型,可以是alert, beforeunload, confirm或 prompt其中一个

    dialog.type

    3.2dialog 事件监听

    playwright 框架可以监听dialog事件,不管你alert 什么时候弹出来,监听到事件就自动处理了。

    当出现 JavaScript 对话框时发出,例如alert、prompt。监听器必须dialog.accept()或dialog.dismiss()对话框 - 否则页面将冻结等待对话框,并且单击等操作将永远不会完成。

    复制代码
    #弹窗中确认
    page.on("dialog", lambda dialog: dialog.accept())
    page.locator("button").click()
    #弹窗中取消
    page.on("dialog", lambda dialog: dialog.dismiss())
    page.locator("button").click()
    复制代码

    注:当没有page.on("dialog")侦听器存在时,所有对话框都会自动关闭。

    语法如下:

    page.on("dialog", handler)

    3.模态框的定义

      模态对话框(Modal Dialogue Box,又叫做模式对话框),是指在用户想要对对话框以外的应用程序进行操作时,必须首先对该对话框进行响应。如单击【确定】或【取消】按钮等将该对话框关闭。一般来说,Windows应用程序中,对话框分为模态对话框和非模态对话框两种。二者的区别在于当对话框打开时,是否允许用户进行其他对象的操作。

    3.1警告框

    警告框经常用于确保用户可以得到某些信息。

    当警告框出现后,用户需要点击确定按钮才能继续进行操作。

    语法:

    alert("文本")

    3.2确认框

    确认框用于使用户可以验证或者接受某些信息。

    当确认框出现后,用户需要点击确定或者取消按钮才能继续进行操作。

    如果用户点击确认,那么返回值为 true。如果用户点击取消,那么返回值为 false。

    语法:

    confirm("文本")

    3.3提示框

    提示框经常用于提示用户在进入页面前输入某个值。

    当提示框出现后,用户需要输入某个值,然后点击确认或取消按钮才能继续操纵。

    如果用户点击确认,那么返回值为输入的值。如果用户点击取消,那么返回值为 null。

    语法:

    prompt("文本","默认值")

    3.4测试页面准备

    ModalDialogueBox.html页面参考代码如下:

    复制代码
    
    
    
    
    模态框
    
    
    
    
        

    测试练习模态框的处理:

    1.警告框

    2.确认框

    3.提示框

    复制代码

    浏览器打开页面如下图所示:

    4.牛刀小试

    下边宏哥就利用上边准备好的模态框例子进行一下演示。首先演示当监听器存在时,我们如何处理。

    监听器存在

    4.1代码设计

    4.2参考代码

    复制代码
    # coding=utf-8🔥
    
    # 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行
    
    # 2.注释:包括记录创建时间,创建人,项目名称。
    '''
    Created on 2023-07-14
    @author: 北京-宏哥   QQ交流群:705269076
    公众号:北京宏哥
    Project: 《最新出炉》系列初窥篇-Python+Playwright自动化测试-15-处理模态对话框弹窗
    '''
    
    # 3.导入模块
    from playwright.sync_api import sync_playwright
    
    def run(playwright):
        chromium = playwright.chromium
        browser = chromium.launch(headless=False, slow_mo=3000)
        page = browser.new_page()
        page.goto("C:/Users/DELL/Desktop/test/ModalDialogueBox.html")
        page.on("dialog", lambda dialog: dialog.accept())
        page.on("dialog", lambda dialog: print(dialog.message))
        # 点击弹出警告框
        page.locator("#input_1").click()
        # 点击弹出警告框
        page.wait_for_timeout(5000)
        page.locator("#input_2").click()
        # 点击弹出警告框
        page.wait_for_timeout(5000)
        page.locator("#input_3").click()
        browser.close()
    
    with sync_playwright() as playwright:
        run(playwright)
    复制代码

    4.3运行代码

    1.运行代码,右键Run'Test',控制台输出,如下图所示:

    2.运行代码后电脑端的浏览器的动作。如下图所示:

    监听器不存在

    4.4代码设计

    4.5参考代码

    复制代码
    # coding=utf-8🔥
    
    # 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行
    
    # 2.注释:包括记录创建时间,创建人,项目名称。
    '''
    Created on 2023-07-14
    @author: 北京-宏哥   QQ交流群:705269076
    公众号:北京宏哥
    Project: 《最新出炉》系列初窥篇-Python+Playwright自动化测试-15-处理模态对话框弹窗
    '''
    
    # 3.导入模块
    from playwright.sync_api import sync_playwright
    
    def run(playwright):
        chromium = playwright.chromium
        browser = chromium.launch(headless=False, slow_mo=3000)
        page = browser.new_page()
        page.goto("C:/Users/DELL/Desktop/test/ModalDialogueBox.html")
        # page.on("dialog", lambda dialog: dialog.accept())
        # page.on("dialog", lambda dialog: print(dialog.message))
        # 点击弹出警告框
        page.locator("#input_1").click()
        # 点击弹出警告框
        page.wait_for_timeout(5000)
        page.locator("#input_2").click()
        # 点击弹出警告框
        page.wait_for_timeout(5000)
        page.locator("#input_3").click()
        browser.close()
    
    with sync_playwright() as playwright:
        run(playwright)
    复制代码

    4.6运行代码

    1.运行代码,右键Run'Test',控制台输出,如下图所示:

    2.运行代码后电脑端的浏览器的动作。如下图所示:

    5.项目实战

    宏哥继续用java+selenium中的一个alert例子(http://news.cyol.com/node_60799.htm),只有点击确定这个按钮,alert框才会消失。

    5.1参考代码

    复制代码
    # coding=utf-8🔥
    
    # 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行
    
    # 2.注释:包括记录创建时间,创建人,项目名称。
    '''
    Created on 2023-07-14
    @author: 北京-宏哥   QQ交流群:705269076
    公众号:北京宏哥
    Project: 《最新出炉》系列初窥篇-Python+Playwright自动化测试-15-处理模态对话框弹窗
    '''
    
    # 3.导入模块
    from playwright.sync_api import sync_playwright
    
    def run(playwright):
        chromium = playwright.chromium
        browser = chromium.launch(headless=False, slow_mo=3000)
        page = browser.new_page()
        page.on("dialog", lambda dialog: dialog.accept())
        page.on("dialog", lambda dialog: print(dialog.message))
        page.goto("http://news.cyol.com/node_60799.htm")
        browser.close()
    
    with sync_playwright() as playwright:
        run(playwright)
    复制代码

    5.2运行代码

    1.运行代码,右键Run'Test',控制台输出,如下图所示:

    2.运行代码后电脑端的浏览器的动作。如下图所示:

    6.小结

    page.on(“dialog”)监听器必须处理该对话框。否则您的操作将停止,无论是 locator.click() 还是其他内容。这是因为Web中的对话框是模态,因此在处理它们之前会阻止进一步的页面执行。

    例如下边宏哥演示的是:只打印message,而没有处理就会一直卡在那个弹出框不继续往下操作了。宏哥就是将处理代码注释,打印代码留下。不过这种情况你手动点击“确定”,代码也是可以向下执行的。

    # page.on("dialog", lambda dialog: dialog.accept())
    page.on("dialog", lambda dialog: print(dialog.message))

     运行代码后电脑端的浏览器的动作(可以看到卡主不动了,也就是代码不向下执行了)。如下图所示:

     好了,今天时间也不早了,宏哥就讲解和分享到这里,感谢您耐心的阅读,希望对您有所帮助。

  • 相关阅读:
    阿里二面:SpringBoot可以同时处理多少个请求?当场懵了。。。。
    QT5.14.2 视频分帧:QT与FFmpeg的高效结合
    Leetcode(34)——在排序数组中查找元素的第一个和最后一个位置
    vue 使用 this.$router.push 传参数,接参数的 query或params 两种方法示例
    spring boot整合thymeleaf接口返回接口返回html数据浏览器不显示
    【WPF应用30】WPF中的ListBox控件详解
    .net----数组和指针
    外部访问win服务器的mysql数据库
    FANUC机器人用户自定义报警的具体配置方法详解
    XC5VLX30T-2FF323I Virtex-5 LXT FPGA IC 产品参数
  • 原文地址:https://www.cnblogs.com/du-hong/p/17547561.html