решил покопаться в исходниках apollographql/apollo-client и, как мне кажется, проект загибается:
Комьюнити в Spectrum тупо мертво, в гитхабе 80% тикетов остается даже без ответа.
Я решил помочь одному чуваку по тикету и закрыть баг самостоятельно:
https://github.com/apollographql/apollo-client/issues/7667
Простой баг:
- useQuery
- если включить, выключить, включить polling через флаг skip, то он перестает работать
Скачал репу, запустил тесты - 7 тестов красные
Запускаю еще раз - 5 тестов красные
Короче, оказалось, что есть тесты, которые то срабатывают то нет
Стал разбираться, что за дела, решил поправить этот косяк
Полный отчет с кодом можно тут прочесть
https://github.com/apollographql/apollo-client/pull/7679
Вкратце: тест coupled с деталями имплементации реакта
Супер красный флаг
Возвращаясь к тому багу, мне легко удалось написать тест, который этот баг повторяет, но вот поправить этот баг мне не удалось
Код непонятный
Пример
https://github.com/apollographql/apollo-client/blob/main/src/react/data/QueryData.ts
- Данные мутируются из рандомных мест
- Огромные комментарии, которые пытаюсь объяснять арканную магию, почему if из 6 строчек на 3-м уровне вложенности очень важный
- Переплетеная слоистая архитектура из объектов с кризисом самоидентификации. Что делает QueryData? Я хз, что-то запрашивает, наверное данные. Лениво, сразу, с поллингом, менеджит конфигурацию, работает с кешем, рендрит SSR, хранит текущий и предыдуший стэйт…
Conclusion
- код сложный из-за косяков с архитектурой
- фактически в коде разбирается только один чувак по имени Ben Newman
- нового эксперта не предвидится: комьюнити мертво, в коде сложно разобраться
- багов в коде много, но их поправвить может только Ben Newman
- усилий одного человека не достаточно для закрытий всех багов, вот и 80% неотвеченных тикетов
- как мне кажется, проект загибается
Шанс у Apollo есть, если они заменят Ben Newman на новую сработанную команду, и она с нуля перепишет большую часть кода. Но все это туманное отдаленное будущее
Поэтому, товарищи, я вам рекомендую стараться уходить от React Apollo Client
Спасибо, что пришли на мой Тэд Толк
спасибо
Это вы еще репку Relay не смотрели ) Там вообще на комьюнити болт положили.
а вы точно не из релея?)
Нет ) У меня 2 проекта на Apollo, от релэя я использовал только их протокол пагинации
Обсуждают сегодня