Я тестирую компонент при клике на который я вызываю setState(prev => ({...prev, active: 1})), грубо говоря просто меняю в стейте 1 поле с сохранением старых значений, как узнать что я передал в setState при тестировании? Тесты пишут что приходит анонимная функция, что логично, есть вариант как-либо мокнуть setState?
Вам нельзя лезть в состояние компонента, это его внутреннее дело
Дык я не лезу в состояние, просто хочу мокнуть useState и потом чекнуть результат вызова setState
То, что компонент использует useState - это внутренняя деталь его реализации Или я не понял чего вы хотите
Вы хотите в реакт тиму устроится?
Ды просто компонент условно сетит данные при получение, а я хочу быть уверенным что данные засетелись правильно. Проблема в том что я могу посмотреть что сетит функция, но как только использую такую конструкцию setState(prev => ({...prev, data: data})), то setState получает анонимную функцию с prev стейтом и при тесте пишет что setState сохраняет эту Анонимную функцию. Я вот думаю, можно ли мокнуть setState так, чтобы мы прокинули в него замоканный стейт
Тогда вы на верном пути, тестирует работу сетера стейта
вот сейчас не понял, не могу соединить слова в смысол
Тестируете работу внутренней логики реакта
это вопрос или утверждение? Я не тестирую внутреннюю логику, я просто пытаюсь быть уверенным что у меня правильные данные с сервера прилетают
Что потом с этими данными делает компонент?
Вот и проверяйте то место где эти данные уже используются
Если по простому, вызвав setState(1) мы можем ожидать, что он вернет 1 и даже это легко тестируется. Но как только внуть setState прокидвается (prev) => ({...prev, data:data}) , то все, габелла
Зачем проверять все компоненты, если легче посмотреть как они прилетают? К тому же надо тестить не что-то одно, а все.
Да потому, что вы таким образом пишете хрупкие тесты, которые тестируют не поведение, а детали реализации
в каком смысле детали реализации? Я просто хочу уверенным быть, что юзер правильные данные при клике получает. Просто все ломается из-за анонимной функции.
Обсуждают сегодня