详解 Chai.js 中 sinon-chai 可增强断言的用法

阅读时长 6 分钟读完

在前端开发中,测试是不可或缺的一部分。而在测试中,断言是非常重要的一个环节。Chai.js 是一个流行的断言库,它提供了很多不同的断言方式,可以帮助我们更方便地编写测试用例。其中,sinon-chai 是 Chai.js 的一个插件,它可以增强 Chai.js 的断言功能,让我们能够更加灵活地编写测试用例。本文将详细介绍 sinon-chai 的用法,并提供示例代码以帮助读者更好地理解。

什么是 sinon-chai

sinon-chai 是 Chai.js 的一个插件,它基于 sinon.js,提供了一些新的断言方式,使得我们可以更加方便地测试一些需要模拟或者 spy 的场景。sinon.js 是一个 mock 和 stub 库,它可以模拟一些外部依赖或者测试代码中的一些函数调用,从而使得我们能够更好地控制测试环境。通过结合 Chai.js 和 sinon.js,sinon-chai 为我们提供了更加强大的测试能力。

安装和使用

安装 sinon-chai 可以通过 npm 命令来完成:

然后在测试代码中,我们可以通过以下方式来引入 sinon-chai:

这样我们就可以使用 sinon-chai 提供的断言了。

常用的断言方式

sinon-chai 提供了很多不同的断言方式,这里我们介绍其中一些常用的方式。

to.have.been.called

这个断言用于判断一个函数是否被调用过。示例代码如下:

-- -------------------- ---- -------
----- ----- - -----------------
----- ---- - ----------------
----- --------- - ----------------------

--------------------

---------------- ---------- -
  ---------- ---- --- ---------- ---------- -
    ----- --- - ------------
    ------
    -------------------------------------
  ---
---

这个测试用例中,我们创建了一个 spy,然后调用了这个 spy。最后我们使用 to.have.been.called 断言来判断这个 spy 是否被调用过。如果被调用过,这个测试用例就会通过。

to.have.been.calledOnce

这个断言用于判断一个函数是否只被调用过一次。示例代码如下:

-- -------------------- ---- -------
----- ----- - -----------------
----- ---- - ----------------
----- --------- - ----------------------

--------------------

---------------- ---------- -
  ---------- ---- --- -------- ------ ---------- -
    ----- --- - ------------
    ------
    -----------------------------------------
  ---
---

这个测试用例中,我们创建了一个 spy,然后调用了这个 spy。最后我们使用 to.have.been.calledOnce 断言来判断这个 spy 是否只被调用过一次。如果被调用过一次,这个测试用例就会通过。

to.have.been.calledWith

这个断言用于判断一个函数是否被调用时传入了指定的参数。示例代码如下:

-- -------------------- ---- -------
----- ----- - -----------------
----- ---- - ----------------
----- --------- - ----------------------

--------------------

---------------- ---------- -
  ---------- ---- --- -------- ---- --------- ----------- ---------- -
    ----- --- - ------------
    ------ -- ---
    ------------------------------------------- -- ---
  ---
---

这个测试用例中,我们创建了一个 spy,然后调用了这个 spy,并且传入了三个参数。最后我们使用 to.have.been.calledWith 断言来判断这个 spy 是否被调用时传入了指定的参数。如果传入的参数和指定的参数一致,这个测试用例就会通过。

to.have.been.calledWithExactly

这个断言用于判断一个函数是否被调用时传入了指定的参数,并且传入的参数和指定的参数一模一样。示例代码如下:

-- -------------------- ---- -------
----- ----- - -----------------
----- ---- - ----------------
----- --------- - ----------------------

--------------------

---------------- ---------- -
  ---------- ---- --- -------- ---- --------- --------- --------- ---------- -
    ----- --- - ------------
    ------ -- ---
    -------------------------------------------------- -- ---
  ---
---

这个测试用例中,我们创建了一个 spy,然后调用了这个 spy,并且传入了三个参数。最后我们使用 to.have.been.calledWithExactly 断言来判断这个 spy 是否被调用时传入了指定的参数,并且传入的参数和指定的参数一模一样。如果传入的参数和指定的参数一致,这个测试用例就会通过。

to.have.returned

这个断言用于判断一个函数的返回值是否符合预期。示例代码如下:

-- -------------------- ---- -------
----- ----- - -----------------
----- ---- - ----------------
----- --------- - ----------------------

--------------------

---------------- ---------- -
  ---------- ------ --- --------- ------- ---------- -
    ----- ---- - -------------------------
    -----------------------------------------
  ---
---

这个测试用例中,我们创建了一个 stub,然后让它返回了一个值 42。最后我们使用 to.have.returned 断言来判断这个 stub 的返回值是否符合预期。如果返回值符合预期,这个测试用例就会通过。

总结

通过本文的介绍,我们了解了 sinon-chai 的基本用法,以及常用的断言方式。sinon-chai 可以帮助我们更加灵活地编写测试用例,特别是在需要模拟或者 spy 的场景下。通过使用 sinon-chai,我们可以更好地控制测试环境,从而提高测试覆盖率和测试质量。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/6580306bd2f5e1655db5851f

纠错
反馈