javascript - 如何测试一个调用另一个函数的函数?

标签 javascript jestjs

我有一个函数可以将 8 位整数数组转换为 x 位整数。这个函数在 Jest 中有大量的单元测试。此函数称为 convertArrayIntoInt()

我有另一个依赖于 convertArrayIntoInt() 的函数,称为 getSignature()

/**
 * @param {Uint8Array} fileContents The file contents
 * @param {number} position The position in the file where the signature is.
 * @return {number} the 32 bit signature
 */
function getSignature(fileContents, position) {
    let signature = fileContents.slice(position, position + 4);
    signature = convertArrayIntoInt(signature);
    for(let s in Enums.Signatures) {
        if(signature === parseInt(s)) {
            return signature;
        }
    }
    return Enums.Signatures.BAD_SIGNATURE;
}

我想为此函数编写一个测试,测试 Uint8Array.of(0x04, 0x03, 0x4b, 0x50), 0) 是否返回 0x04034b50枚举.BAD_SIGNATURE。我听说通过单元测试,您不想测试依赖于另一个函数输出的函数。我如何在 Jest 中执行此操作?

最佳答案

更新:当我将不同的文件合并到一个文件中时,我的原始响应似乎出现了一些问题我希望它能像以前一样工作,但它没有 因此请确保将要注入(inject)的函数放入单独的文件中。

如前所述,单元测试应该在模拟依赖项时测试它自身的功能。

我将函数移到单独的文件中,在一个文件中定义了所有函数并在另一个测试中。

枚举.js

export const Enums = {
  Signatures: {
    SIGNATURE_1: 1,
    SIGNATURE_2: 2,
    SIGNATURE_3: 3,
    BAD_SIGNATURE: -1
  }
};

convertArrayIntoInt.js

export function convertArrayIntoInt(array) {
  // processing...
  return array.length;
}

getSignature.js

import { convertArrayIntoInt } from "./convertArrayIntoInt";
import { Enums } from "./enums";

export const getSignature = (fileContents, position) => {
  let signature = convertArrayIntoInt(
    fileContents.slice(position, position + 4)
  );

  for (let s in Enums.Signatures) {
    if (signature === parseInt(s, 10)) {
      return signature;
    }
  }

  return signature;
};

tests.spec.js

import { getSignature } from "./getSignature";
import { Enums } from "./enums";
import * as convertArrayIntoIntModule from "./convertArrayIntoInt";

it("Function check", () => {
  // arrange
  const spy = jest.spyOn(convertArrayIntoIntModule, "convertArrayIntoInt");
  spy.mockReturnValue(Enums.Signatures.SIGNATURE_1);

  // act
  const expected = Enums.Signatures.SIGNATURE_1;
  const actual = getSignature([1, 2, 3, 4, 5, 6], 1);

  // assert
  expect(spy).toBeCalledTimes(1);
  expect(actual).toEqual(expected);

  // clean up
  spy.mockRestore();
});

可以看看this sandbox我创建的是为了测试类似于您的虚拟函数。

关于javascript - 如何测试一个调用另一个函数的函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63872226/

相关文章:

git - Jest - 查找相关测试并在 `pre-commit` Hook 上运行

javascript - 使用 Chrome 扩展,如何使用长期连接(端口)将消息从后台脚本传递到内容脚本?

javascript - 映射 jQuery 对象数组不起作用?

javascript - 如何使用 Angular 处理 RxJS 中的错误

javascript - 由于 Unresolved promise ,Jest 中的异步测试失败

javascript - 在 React 测试库中发现多个元素错误

javascript - JavaScript的严格模式对隐式全局声明到底有什么作用?

javascript - 清除上次创建的计时器对象的超时

jestjs - 试图运行 jest 的 jest 版本不正确

javascript - enzyme 测试容器