#javascript #unit-testing #redux #redux-saga #redux-saga-test-plan
Вопрос:
У меня есть генератор, который я хочу покрыть модульным тестом
export default function* gatawayFlow() {
yield all([
takeEvery(actionTypes.GET_GATEWAYS_REQUEST, getGatewaysFlow),
takeLatest(actionTypes.SELECT_GATEWAY_REQUEST, selectGatewayFlow),
]);
}
Я написал простой тест с redux-sag-планом тестирования
import {expectSaga, testSaga} from 'redux-saga-test-plan';
import gatawayFlow, {getGatewaysFlow, selectGatewayFlow} from '../logic/sagas';
import * as actions from '../logic/actions';
import * as actionTypes from '../logic/actionTypes';
import {takeEvery, takeLatest} from '@redux-saga/core/effects';
// Unit-test
describe('Unit tests', () => {
test('Test all effect', () => {
const saga = testSaga(gatawayFlow);
saga
.next()
.all({
[actionTypes.GET_GATEWAYS_REQUEST]: takeEvery(actionTypes.GET_GATEWAYS_REQUEST, getGatewaysFlow),
[actionTypes.SELECT_GATEWAY_REQUEST]: takeLatest(actionTypes.SELECT_GATEWAY_REQUEST, selectGatewayFlow)
})
.next()
.isDone();
// expect(gatawayFlow().next().value).toEqual(all([
// takeEvery(actionTypes.GET_GATEWAYS_REQUEST, getGatewaysFlow),
// takeEvery(actionTypes.SELECT_GATEWAY_REQUEST, selectGatewayFlow),
// ])); ---> THIS TEST WORKS CORRECT
});
});
И мой тест не прошел. У меня эта ошибка в моем терминале. Есть какие-нибудь идеи, как я могу это решить?
Ответ №1:
Вы должны использовать все([…эффекты]) — параллельные эффекты вместо объекта словаря формы {label: effect, ...}
saga.ts
:
import { all, takeEvery, takeLatest } from 'redux-saga/effects';
export const actionTypes = {
GET_GATEWAYS_REQUEST: 'GET_GATEWAYS_REQUEST',
SELECT_GATEWAY_REQUEST: 'SELECT_GATEWAY_REQUEST',
};
export function* getGatewaysFlow() {}
export function* selectGatewayFlow() {}
export default function* gatawayFlow() {
yield all([
takeEvery(actionTypes.GET_GATEWAYS_REQUEST, getGatewaysFlow),
takeLatest(actionTypes.SELECT_GATEWAY_REQUEST, selectGatewayFlow),
]);
}
saga.test.ts
:
import { expectSaga, testSaga } from 'redux-saga-test-plan';
import gatawayFlow, { actionTypes, getGatewaysFlow, selectGatewayFlow } from './saga';
import { takeEvery, takeLatest } from '@redux-saga/core/effects';
describe('Unit tests', () => {
test('Test all effect', () => {
const saga = testSaga(gatawayFlow);
saga
.next()
.all([
takeEvery(actionTypes.GET_GATEWAYS_REQUEST, getGatewaysFlow),
takeLatest(actionTypes.SELECT_GATEWAY_REQUEST, selectGatewayFlow),
])
.next()
.isDone();
});
});
результат теста:
PASS redux-saga-examples packages/redux-saga-examples/src/stackoverflow/69252089/saga.test.ts
Unit tests
✓ Test all effect (2 ms)
----------|---------|----------|---------|---------|-------------------
File | % Stmts | % Branch | % Funcs | % Lines | Uncovered Line #s
----------|---------|----------|---------|---------|-------------------
All files | 75 | 100 | 20 | 100 |
saga.ts | 75 | 100 | 20 | 100 |
----------|---------|----------|---------|---------|-------------------
Test Suites: 1 passed, 1 total
Tests: 1 passed, 1 total
Snapshots: 0 total
Time: 3.553 s
Ran all test suites related to changed files.
Комментарии:
1. Спасибо. Не могли бы вы, пожалуйста, рассказать мне, как вы запустили сценарий покрытия для плана тестирования redux-saga? Я попытался запустить это
npm test -- --coverage
, но вижу только файлы, которые я написал в шутку2. Конфигурация @ElliZorro testPathIgnorePatterns игнорируется
node_modules
, вам не нужно тестировать стороннюю библиотеку. Вы должны использовать полностью проверенную библиотеку