51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 1037|回复: 0
打印 上一主题 下一主题

[转贴] 基于react的前端单元测试

[复制链接]
  • TA的每日心情
    无聊
    前天 09:06
  • 签到天数: 941 天

    连续签到: 3 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2022-4-11 10:59:43 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
     一、为什么需要单元测试
      降低bug率:通过单元测试能更早的发现问题,减少线上出现的bug率。
      提升代码能力:单元测试可以让开发者去思考代码的逻辑,从而提高编程能力。
      提高信心:如果单元测试都能通过的话,无形中也会提高开发者的信心。
      二、单元测试概念
      单元测试(unit testing),是指对软件中的最小可测试单元进行检查和验证。 在过程化编程中,一个单元就是单个程序、函数、过程等;对于面向对象编程,最小单元就是方法,包括基类(超类)、抽象类、或者派生类(子类)中的方法。
      三、如何去做单元测试
      单元测试的原则
      F-FAST(快速原则):单元测试应该是可以快速运行的,在各种测试方法中,单元测试的运行速度是最快的,通常应该在几分钟内运行完毕。
      I-Independent(独立原则):单元测试应该是可以独立运行的,单元测试用例互相无强依赖,无对外部资源的强依赖。
      R-Repeatable(可重复原则):单元测试应该可以稳定重复的运行,并且每次运行的结果都是相同的。
      S-Self Validating(自我验证原则):单元测试应该是用例自动进行验证的,不能依赖人工验证。
      T-Timely(及时原则):单元测试必须及时的进行编写,更新和维护,以保证用例可以随着业务代码的变化动态的保障质量。
      常用的单元测试工具
      ·测试框架:Mocha, Jasmine, Jest, Cucumber
      · 提供断言:Chai, Jasmine, Jest, Unexpected
      · 生成,展示测试结果:Mocha, Jasmine, Jest, Karma
      · 生成测试覆盖率报告:Istanbul, Jest, Blanket
      四、单元测试的环境配置
      第一步:创建react项目
    npx create-react-app react-test
      cd react-test
      yarn start

    第二步:安装Jest

    yarn add -D Jest

    注意:只安装Jest,然后在.test.js文件里面如果需要import 文件的时候这里会出错,因为Jest默认使用的是CommonJS来导入导出的,因此需要babel来让它支持ESModule的方式。

    1.  npm install --save-dev @babel/core @babel/preset-env @babel/preset-react
    复制代码
     根目录下创建babel.config.js

    1.  module.exports = {
    2.     presets: [
    3.       ["@babel/preset-env", { targets: { node: "current" } }],
    4.       "@babel/preset-react",
    5.     ],
    6.   };
    复制代码
    第三步:配置Jest

     npx jest --init



      生成jest.config.js,同时查看package.json发现scripts的命令里面多了个test,后面每次写好测试文件的时候,执行npm run test就可以啦。

      第四步:写个简单的demo测试下
      首先写个Counter组件:
    1.  export default class Counter {
    2.       constructor() {
    3.           this.number = 0
    4.       }
    5.       add() {
    6.           this.number += 1;
    7.       }
    8.       minus() {
    9.           this.number -= 1
    10.       }
    11.   }
    复制代码
    接着写个测试Counter的测试文件:

    1.  import Counter from '../components/Counter'
    2.   const counter = new Counter()
    3.   test('测试Counter中的add方法',()=>{
    4.       counter.add()
    5.       expect(counter.number).toBe(1)
    6.   })
    7.   test('测试Counter中的minus方法',()=>{
    8.       counter.minus()
    9.       expect(counter.number).toBe(0)
    10.   })
    复制代码
    最后运行npm run test,结果如下:


    五、react项目的单元测试
      组件测试
      一般组件我们是通过生成组件快照来测试的。
      1. 安装react-test-renderer,用这个插件来渲染快照
    yarn add --dev react-test-renderer

     2. 组件
    import React, { useState } from 'react'
      const STATUS = {
          hovered: 'hovered',
          normal: 'normal'
      }
      const Link = ({page, children})=>{
          const [status, setStatus] = useState(STATUS.normal)
          const onMouseEnter = ()=>{
              setStatus(STATUS.hovered)
          }
          const onMouseLeave = ()=>{
              setStatus(STATUS.normal)
          }
          return (
              <a
                  className={status}
                  href={page || '#'}
                  onMouseEnter={onMouseEnter}
                  onMouseLeave={onMouseLeave}
              >
                  {children}
              </a>
          )
      }
      export default Link

     3. 测试组件以及组件函数
    import React from 'react'
      import renderer from 'react-test-renderer'
      import Link from '../components/Counter'
      test('Link changes the class when hovered', ()=>{
          const component = renderer.create(
              <Link page='http://www.baidu.com'>百度</Link>
          )
          let tree = component.toJSON()
          expect(tree).toMatchSnapshot()
          tree.props.onMouseLeave()
          tree = component.toJSON()
          expect(tree).toMatchSnapshot()
      })

    4.函数组件测试
      针对react hooks的测试可以使用React-hooks-testing-library,这个包对react 版本是有要求的,需要react是16.9.0及以上。
      函数测试
      同步函数测试
      就是步骤四的最后demo所示,获取的组件实例之后直接调用方法看方法所得结果是否符合预期即可。
      异步函数测试
      异步函数主要有两个方式可以进行测试,第一个是用done,第二个是利用promise。
    1.  import React from 'react'
    2.   const Counter = ({page, children})=>{
    3.       const onClick = (cb)=>{
    4.           setTimeout(()=>{
    5.               cb('您好呀')
    6.           }, 1000)
    7.       }
    8.       return (
    9.           <div onClick={onClick}>测试按钮呀</div>
    10.       )
    11.   }
    12.   export default Counter
    复制代码
    1.  import React from 'react'
    2.   import renderer from 'react-test-renderer'
    3.   import Counter from '../components/Counter'
    4.   test('Link changes the class when hovered', (done)=>{
    5.       const component = renderer.create(<Counter />)
    6.       let tree = component.toJSON()
    7.       tree.props.onClick((val)=>{
    8.           expect(val).toBe('您好呀')
    9.           done()
    10.       })
    11.   })
    复制代码






    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

    x
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-5-2 06:01 , Processed in 0.066663 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表