reactjs - 在 Sagas 测试中没有调用我的模拟函数

标签 reactjs react-native testing jestjs saga

我正在尝试用 Jest 测试 Sagas,但我无法让 Sagas 调用 loginApi 模拟函数,看来它正在调用实际函数。有人可以帮我弄这个吗?

这就是我的传奇:

export async function loginApi(user) {
  return await api.post('/auth/customers/login', {
    email: user.email, //customer1@mi.me
    password: user.password, //12345678
  });
}

// Saga function that handles the side effect when the loginWatcher is triggered
export function* loginActionEffect(loginAction) {
  //console.tron.log('login Action Effect');

  try {
    const response = yield call(loginApi, loginAction.user);
    // console.log('response:' + response);

    yield AsyncStorage.setItem('access_token', response.data.access_token);
    yield put(LoginActions.setLogin(loginAction.user));
    yield put(LoginActions.setError(''));
  } catch (e) {
    //console.log('problema com o login!');
    yield put(LoginActions.setError('Email ou senha incorretos!'));
  }
}

那是我的测试:
it('should receive token in case of success', async () => {
    const mockToken = {token: 'kaajfalkfjlaniurvayeg'};
    const loginApi = jest.fn().mockImplementation(() => Promise.resolve(mockToken));
    const dispatched = [];

    const result = await runSaga(
      {
        dispatch: action => dispatched.push(action),
      },
      loginActionEffect,
    );

    expect(loginApi).toHaveBeenCalled();
    expect(dispatched).toContainEqual(Creators.setLogin());
    expect(dispatched).toContainEqual(Creators.setError());
    loginApi.mockClear();
  });

这就是我的测试结果:
expect(jest.fn()).toHaveBeenCalled()

Expected number of calls: >= 1
Received number of calls:    0

  21 |     );
  22 | 
> 23 |     expect(loginApi).toHaveBeenCalled();
     |                      ^

最佳答案

runSaga返回 Task对象不是 Promise所以你需要调用toPromise

const result = await runSaga(
  {
    dispatch: action => dispatched.push(action),
  },
  loginActionEffect,
).toPromise();

PS。您测试 sagas 的方式与推荐的不符。请阅读 docs .正如我在评论中所写。声明式效果的一件很酷的事情是效果执行依赖于解释器。因此,您不需要在测试中实际执行或模拟任何内容。

关于reactjs - 在 Sagas 测试中没有调用我的模拟函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59755276/

相关文章:

javascript - React Native - 从父级到子级的级联状态更新

java - 如何测试接收到的输入是否不是整数(不使用else语句)

android - RealmDB - React Native - 无法在路径 '.management' 打开 Realm

javascript - 如何使用 React 在客户端裁剪图像而不丢失分辨率

javascript - 如何从Firebase中获得对当前用户的访问权限?

reactjs - 如何防止父组件使用 React (next.js) SSR 两遍渲染重新渲染?

javascript - 是否可以在React Native中从其无状态组件子级更改父级的状态?

Django 模型对象不会在测试环境中以 Form 加载

macos - 多平台应用程序 : (Automated) Testing for Mac OSX howto?

javascript - 如何在 redux 操作中每次执行多个函数只使用一个循环