Puppeteer结合测试工具jest使用(四)

Puppeteer结合测试工具jest使用(四)

在这里插入图片描述

    • Puppeteer结合测试工具jest使用(四)
        • 一、简介
        • 二、与jest结合使用,集成到常规测试
        • 三、支持其他的几种
        • 四、总结

一、简介
  • Puppeteer是一个提供自动化控制Chrome或Chromium浏览器的Node.js库, Puppeteer支持与node测试工具进行配合集成,集成到一起进行自动化测试。

  • Jest 是由 Facebook 提供的一款 JavaScript 测试框架,它可以帮助我们编写可靠的测试用例,并能够实现断言、mock 函数等功能。Jest 能够帮助我们做单元测试、集成测试以及 UI 测试等,与 Puppeteer 结合使用可以实现更全面的 UI 测试。

二、与jest结合使用,集成到常规测试

不熟悉jest使用的小伙伴可以先去看看jest的大概使用方法,jest测试框架官方网址:https://jestjs.io/docs/getting-started

下面我们在我们的项目中进行集成jest框架,集成过程也是比较简单的。

  • 安装jest三方库
npm install --save-dev jest
  • package.json中,在scripts对象下配置脚本

项目路径下,package.json中的scripts对象下配置脚本测试脚本,方便我们直接使用 npm 进行执行。

"test": "jest",
  • 创建测试文件 csdnJest.test.js

项目目录下创建文件,命名为 csdnJest.test.js ,同时将下面的内容添加到文件中。

const puppeteer = require('puppeteer');let browser;
let page;beforeAll(async () => {browser = await puppeteer.launch({headless: false,slowMo: 80,defaultViewport: null, // 不使用默认的固定大小,直接填满浏览器});page = await browser.newPage();page.on('dialog', async dialog => {console.log(dialog.message());await dialog.dismiss();await dialog.dismiss();await dialog.dismiss();});
});afterAll(() => {browser.close();
});test('open csdn page', async () => {await page.goto('https://www.csdn.net/');await page.waitForSelector('a.title');
});test('expect h3 is 头条', async () => {await page.waitForSelector('h3');const text = await page.$eval('h3', el => el.textContent);expect(text).toBe('头条');
});

在上述代码中,我们创建了一个测试套件,并在 beforeAllafterAll 钩子函数中创建和关闭浏览器。

总共有两个小的测试用例:

  • 测试用例 ‘open csdn page’
    我们使用page.goto方法打开了一个网页 https://www.csdn.net/ ,并等待页面中选择器 ‘a.title’ 的出现。

  • 测试用例 ‘expect h3 is 头条’
    我们等待h3标签的出现,并且获取到h3标签的内容,然后我们使用 expect 断言判断页面h3的内容是 头条

运行脚本,查看实际表现:

npm run test

在这里插入图片描述

在运行过程中,Puppeteer将自动控制Chrome浏览器,打开指定的网页,并执行我们的测试用例。运行结束后,我们将在命令行中看到测试用例的执行结果。

我们能够看到结果中,所有的测试用例都是通过的。

三、支持其他的几种

当然,Puppeteer不仅仅支持jest集成,其实应该能够集成其他几种node类型的测试框架,有兴趣的同学可以自行去尝试下集成到自己的项目中进行使用。
比如以下一些常见的框架:

  • Jasmine
  • Jest
  • Mocha
  • Node Test Runner
四、总结

通过结合Puppeteer和Jest进行自动化端到端测试,我们可以有效地测试和验证Web应用程序的各种功能,从而提高测试效率和测试质量。有兴趣的小伙伴也可以去试试其他支持的测试框架集成。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/136432.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

windows10系统-16-制作导航网站WebStack-Hugo

上个厕所功夫把AI导航搞定了 使用Hugo搭建静态站点 如何使用Hugo框架搭建一个快如闪电的静态网站 1 Hugo 参考Hugo中文文档 参考使用Hugo搭建个人网站 Hugo是由Go语言实现的静态网站生成器。简单、易用、高效、易扩展、快速部署。 1.1 安装Hugo 二进制安装(推荐…

Android 内容提供者和内容观察者:数据共享和实时更新的完美组合

任务要求 一个作为ContentProvider提供联系人数据另一个作为Observer监听联系人数据的变化: 1、创建ContactProvider项目; 2、在ContactProvider项目中用Sqlite数据库实现联系人的读写功能; 3、在ContactProvider项目中通过ContentProvid…

Linux网络编程系列之UDP组播

Linux网络编程系列 (够吃,管饱) 1、Linux网络编程系列之网络编程基础 2、Linux网络编程系列之TCP协议编程 3、Linux网络编程系列之UDP协议编程 4、Linux网络编程系列之UDP广播 5、Linux网络编程系列之UDP组播 6、Linux网络编程系列之服务器编…

接口测试文档

接口测试的总结文档 第一部分:主要从问题出发,引入接口测试的相关内容并与前端测试进行简单对比,总结两者之前的区别与联系。但该部分只交代了怎么做和如何做?并没有解释为什么要做? 第二部分:主要介绍为什…

ChatGPT,AIGC 数据库应用 Mysql 常见优化30例

使用ChatGPT,AIGC总结出Mysql的常见优化30例。 1. 建立合适的索引:在Mysql中,索引是重要的优化手段,可以提高查询效率。确保表的索引充分利用,可以减少查询所需的时间。如:create index idx_name on table_name(column_name); 2. 避免使用select * :尽可能指定要返回的…

windows计划任务的配置文件

界面操作 创建计划 依次设置 命令行操作 SCHTASKS 命令简介 SCHTASKS 命令是由微软公司开发并内置于 Windows 系统中的一个命令行工具。该命令可用于设置、修改、查询和删除计划任务,或启动计划任务中所定义的程序或脚本。 SCHTASKS 命令的基本语法 SCHTASKS 命…

ios设备管理软件iMazing 2.17.11官方中文版新增功能介绍

iMazing 2.17.11官方中文版(ios设备管理软件)是一款管理苹果设备的软件, Windows 平台上的一款帮助用户管理 IOS 手机的应用程序,软件功能非常强大,界面简洁明晰、操作方便快捷,设计得非常人性化。iMazing官方版与苹果设备连接后&…

win11的右键菜单改成win10的样子

在终端复制一下命令 reg add “HKCU\Software\Classes\CLSID{86ca1aa0-34aa-4e8b-a509-50c905bae2a2}\InprocServer32” /f /ve 回车,会显示成功 再重启资源管理器。这步必须执行,否则是成功的,或者可能重启电脑会成功,但是我没有…

知识付费小程序的推广与用户增长策略

在知识付费小程序开发完成后,推广和用户增长是关键的成功因素。本文将探讨一些推广策略和用户增长方法,并提供代码示例,帮助您在知识付费小程序中实施这些策略。 1. 社交媒体分享功能 在知识付费小程序中添加社交媒体分享功能,…

Spring framework Day11:策略模式中注入所有实现类

前言 什么是策略模式? 策略模式(Strategy Pattern)是一种面向对象设计模式,它定义了算法族(一组相似的算法),并且将每个算法都封装起来,使得它们可以互相替换。策略模式让算法的变…

Vmware Linux虚拟机安装教程(Centos版)

文章目录 1.Vmware-workstation安装软件2.双击下载的安装包开始安装3.打开VMware-workstation,输入密钥4.Centos7.6安装软件5.新建虚拟机6.为虚拟机配置映像文件7.开启虚拟机,配置环境7.1 Install Centos 77.2 选择简体中文字体7.3 软件选择7.4 安装位置…

网络基础(2)

UDP 1.传输层2.再谈端口号3.端口号范围划分4.认识知名端口号(Well-Know Port Number)5.netstat6.pidof7.UDP协议端格式8.UDP的特点9.面向数据报10.UDP的缓冲区11.UDP使用注意事项12.基于UDP的应用层协议 🌟🌟hello,各位读者大大们你们好呀&am…