удается повторить.
Ситуация:
1. Имеется основная Активити A1 с запретом смены ориентации экрана (`android:configChanges="orientation|keyboardHidden"`),
2. В ней находятся фрагменты F1 и F2.
3. Во фрагменте F2 имеются 2 фрагмента F2.1 и F2.2.
4. Во фрагментах F2.1 и F2.2 имеются по одному ReactFragment - RF1 и RF2. Тут важно знать, что это фрагменты из сторонней либы, прямые наследники Fragment, и у них в onCreate дергается родительский метод getActivity для выполнения своих функций.
Как это сейчас работает:
1. Запускается A1
2. в onResume через транзакцию в getSupportFragmentManager ничто подменяется(`replace`) на фрагмент F1 посредством commitAllowingStateLoss
3. После взаимодействия с пользователем фрагмент F1 через транзакцию в getSupportFragmentManager подменяется(`replace`) фрагментом F2 посредством commitAllowingStateLoss
4. В фрагменте F2 имеется импровизированный таббар (пара кнопок для вкладок)
5. В фрагменте F2 в onActivityCreated через транзакцию в getChildFragmentManager добавляется(`add`) фрагмент F2.1, и ставится на резюм (`setMaxLifecycle(it, Lifecycle.State.RESUMED)`) посредством commitAllowingStateLoss
6. В фрагменте F2 при переключении на другую вкладку через транзакцию в getChildFragmentManager добавляется(`add`) фрагмент F2.2, и ставится на резюм (`setMaxLifecycle(it, Lifecycle.State.RESUMED)`), а фрагмент F2.1 прячется(`hide`) и ставится на паузу(`setMaxLifecycle(it, Lifecycle.State.STARTED)`) посредством commitAllowingStateLoss
7. Далее при переключении между табами на F2 фрагмены F2.1 и F2.2 через транзакцию в getChildFragmentManager попеременно прячутся(`hide`) и показываются (`show`) со сменой состояния на паузу(`setMaxLifecycle(it, Lifecycle.State.STARTED)`) и резюм(`setMaxLifecycle(it, Lifecycle.State.RESUMED)`) соответственно посредством commitAllowingStateLoss.
8. В обоих фрагментах F2.1 и F2.2 в onCreateView через транзакцию в getChildFragmentManager ничто подменяется(`replace`) на фрагмент RF1 и RF2 соответственно посредством commit.
9. Так все и работает в нашем приложении.
Проблема:
В какие-то моменты происходит NPE в RF1 или RF2 (неизвестно в каком именно и как), потому что в нем в onCreate метод getActivity вернул null.
Крешей очень много, но нам никак не удается их воспроизвести.
Все гипотезы уже проверены, куда копать - хз.
Вопрос в том, в каких случаях в onCreate фрагмента вообще getActivity возвращает null, и как можно спровоцировать эту ситуацию в нашей схеме?
А для чего в onCreate вызывать getActivity?
Обсуждают сегодня