Поместите ожидание неудовлетворенным в план теста на редукс-сагу - PullRequest
0 голосов
/ 03 января 2019

Итак, у меня есть сага, в которой показаны некоторые данные для отображения в таблице.

Создатели действий:

export const fetchInstanceDataSetAssocSuccess = (records) => {
  return {
    type: actionTypes.FETCH_INSTANCE_DATASETS_ASSOC_SUCCESS,
    records: records
  }
 }

export const fetchInstanceDataSetAssocFailed = (error) => {
  return {
    type: actionTypes.FETCH_INSTANCE_DATASETS_ASSOC_FAILED,
    error: error
  }
}

export const fetchInstanceDataSetAssocStart = () => {
  return {
   type: actionTypes.FETCH_INSTANCE_DATASETS_ASSOC_START
  }
}

export const fetchInstanceDataSetAssoc = () => {
   return {
     type: actionTypes.FETCH_INSTANCE_DATASETS_ASSOC_INITIATE
   }
}

Моя сага выглядит следующим образом

    function * fetchInstanceDataSetAssocSaga (action) {
      yield put(instanceDataSetAssocActions.fetchInstanceDataSetAssocStart())
      const useMockData = yield constants.USE_MOCK_DATA
      if (useMockData) {
        yield delay(constants.MOCK_DELAY_SECONDS * 1000)
      }
      try {
        const res = (useMockData)
         ? (yield constants.INSTANCE_DATASET_ASSOC)
         : (yield call(request, {url: 
         API_URLS.INSTANCE_DATASET_ASSOC_API_ENDPOINT, method: 'GET'}))

    yield put(instanceDataSetAssocActions.fetchInstanceDataSetAssocSuccess(res.data))
    } catch (error) {
       yield 
put(instanceDataSetAssocActions.fetchInstanceDataSetAssocFailed(error))
  }
}

Действие для наблюдения за Сагой выглядит следующим образом

export function * watchInstanceDataSetAssocSaga () {
  yield takeEvery(actionTypes.FETCH_INSTANCE_DATASETS_ASSOC_INITIATE, 
  fetchInstanceDataSetAssocSaga)
}

Тестовые случаи следующие

  describe('load instance dataset assoc table', () => {
  test('update state with  instance-dataset records for landing page',() => {
    const finalState = {
      records: constants.INSTANCE_DATASET_ASSOC.data,
      loading: false,
      error: false
    }
    const requestParam = {url: API_URLS.INSTANCE_DATASET_ASSOC_API_ENDPOINT, method: 'GET'}
    return expectSaga(watchInstanceDataSetAssocSaga)
      .provide([[call(request,requestParam),constants.INSTANCE_DATASET_ASSOC]])
      .withReducer(instanceDataSetAssoc)
      .put(instanceDataSetAssocActions.fetchInstanceDataSetAssocStart())
      .put(instanceDataSetAssocActions.fetchInstanceDataSetAssocSuccess(constants.INSTANCE_DATASET_ASSOC.data))
      .dispatch(instanceDataSetAssocActions.fetchInstanceDataSetAssoc())
      .hasFinalState(finalState)
      .silentRun()
  })
})

Я получаю следующую ошибку за это.

 SagaTestError:
put expectation unmet:
at new SagaTestError (node_modules/redux-saga-test-plan/lib/shared/SagaTestError.js:17:57)
  at node_modules/redux-saga-test-plan/lib/expectSaga/expectations.js:63:13
  at node_modules/redux-saga-test-plan/lib/expectSaga/index.js:572:7
      at Array.forEach (<anonymous>)
  at checkExpectations (node_modules/redux-saga-test-plan/lib/expectSaga/index.js:571:18)

Я правильно следую документам, но все еще получаю вышеуказанную ошибку.

1 Ответ

0 голосов
/ 16 апреля 2019

Возможно, уже поздно, но я нашел ответ, возможно, это поможет вам. Эта ошибка может произойти из-за тайм-аута библиотеки. Попробуйте отключить тайм-аут с помощью исходной ссылки .run (false) https://github.com/jfairbank/redux-saga-test-plan/issues/54

...