Jest:测试生成器函数,产生另一个生成器函数

Hum*_*mer 5 unit-testing reactjs jestjs

我有一个看起来像这样的功能

export function* login(user, page) {
        yield checkIp();
        return yield loginAuth(user, page);
 }
Run Code Online (Sandbox Code Playgroud)

我正在尝试从单元测试中测试登录生成器,如下所示

it('login test', () => {
  const user = { email:"test@test.com", password:"1234" }
 const generator = login (user, {});
 generator.next();
 expect(generator.return().done).toEqual(true); });
Run Code Online (Sandbox Code Playgroud)

这是正确的方法吗?同样在覆盖范围内,我无法覆盖登录生成器函数的返回语句。任何帮助将非常感激。

这也是我第一次在这里发帖,如果我没有正确遵守规则,请原谅我。

Far*_* YZ 9

2021 年更新:Jest 现在支持开箱即用的生成器函数。

您可以使用以下两种方法之一使用 Jest 测试生成器函数:

方法一:

直接测试generator的下一个值:

describe('generator test', () => {
  it('should call generator function', function() {
      const user = { email:"test@test.com", password:"1234" };
      const generator = login(user, {});

      expect(generator.next().value).toBe(SOME_VALUE_HERE));
  });
});
Run Code Online (Sandbox Code Playgroud)

方法二:

您可以使用co包将生成器包装在 Jest 支持的 promise 中。

import co from 'co';

describe('generator test', () => {
  it('should call generator function', co.wrap(function *() {
      const user = { email:"test@test.com", password:"1234" };
      const generator = login(user, {});

      expect(generator).toBe(SOME_VALUE_HERE));
  }));
});
Run Code Online (Sandbox Code Playgroud)

有关其他解决方法和在 Jest 中跟踪功能的详细对话,请访问Jest 中的生成器支持

  • 根据链接的问题,现在支持开箱即用的生成器函数。https://github.com/facebook/jest/pull/5166 (3认同)