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

时间:2017-12-19 23:00:01

标签: reactjs unit-testing jestjs

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

export function* login(user, page) {
        yield checkIp();
        return yield loginAuth(user, page);
 }

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

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

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

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

1 个答案:

答案 0 :(得分:3)

您可以使用以下两种方法之一使用Jest测试您的生成器功能:

方法1:

直接测试生成器的下一个值:

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));
  });
});

方法2:

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

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));
  }));
});

有关其他解决方法的详细对话以及跟踪Jest中的功能,请访问Generator support in Jest

相关问题