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


    Puppeteer结合测试工具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
    
    • 1
    • package.json中,在scripts对象下配置脚本

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

    "test": "jest",
    
    • 1
    • 创建测试文件 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('头条');
    });
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37

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

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

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

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

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

    npm run test
    
    • 1

    在这里插入图片描述

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

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

    三、支持其他的几种

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

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

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


  • 相关阅读:
    【滤波器】基于matlab实现微波带低通高通带通滤波器设计
    【C++多线程那些事儿】多线程的执行顺序如你预期吗?
    [Java]细节与使用经验
    【Flink完全分布式环境搭建及应用,Standalone(开发测试)】
    『力扣每日一题08』验证回文串
    Linux下protobuf和 protobuf-c安装使用
    监控文件事件
    腾讯地图撒点并默认显示点位信息
    【算法刷题日记之本手篇】星际密码与数根
    Windows环境下安装MongoDB数据库
  • 原文地址:https://blog.csdn.net/suwu150/article/details/133623995