Skip to content
This repository has been archived by the owner on Feb 20, 2023. It is now read-only.

Crash in [@ java.lang.ClassCastException: at org.mozilla.fenix.settings.search.SearchEngineListPreference.makeButtonFromSearchEngine(SearchEngineListPreference.kt:2)] #12929

Closed
longmoon77 opened this issue Jul 25, 2020 · 4 comments
Assignees
Labels
b:crash Crashes Fenix: should link to Sentry, Crash-Stats or GPlay info 🐞 bug Crashes, Something isn't working, .. eng:qa:verified QA Verified

Comments

@longmoon77
Copy link

longmoon77 commented Jul 25, 2020

Steps to reproduce

Click Settings and click Search.

Expected behavior

Settings about Search.

Actual behavior

Crash.

Device information

  • Android device: Xiaomi Redmi Note 8 Pro
  • Fenix version: Nightly 200725 06:01
  • Android Version: 10 (MIUI 12, latest patch)
  • SoC: MediaTek Helio G90T (ARM64, ARMv8.2-A)

┆Issue is synchronized with this Jira Task

@longmoon77 longmoon77 added the 🐞 bug Crashes, Something isn't working, .. label Jul 25, 2020
@github-actions github-actions bot added the needs:triage Issue needs triage label Jul 25, 2020
@longmoon77
Copy link
Author

longmoon77 commented Jul 25, 2020

Crash Code

java.lang.ClassCastException: android.widget.LinearLayout cannot be cast to androidx.constraintlayout.widget.ConstraintLayout

java.lang.ClassCastException: android.widget.LinearLayout cannot be cast to androidx.constraintlayout.widget.ConstraintLayout
	at org.mozilla.fenix.settings.search.SearchEngineListPreference.makeButtonFromSearchEngine(SearchEngineListPreference.kt:2)
	at org.mozilla.fenix.settings.search.SearchEngineListPreference.access$makeButtonFromSearchEngine(SearchEngineListPreference.kt:1)
	at org.mozilla.fenix.settings.search.SearchEngineListPreference.refreshSearchEngineViews(SearchEngineListPreference.kt:18)
	at org.mozilla.fenix.settings.search.SearchEngineListPreference.reload(SearchEngineListPreference.kt:2)
	at org.mozilla.fenix.settings.search.SearchEngineListPreference.onBindViewHolder(SearchEngineListPreference.kt:3)
	at androidx.preference.PreferenceGroupAdapter.onBindViewHolder(PreferenceGroupAdapter.java:3)
	at androidx.recyclerview.widget.RecyclerView$Adapter.onBindViewHolder(RecyclerView.java:1)
	at androidx.recyclerview.widget.RecyclerView$Adapter.bindViewHolder(RecyclerView.java:6)
	at androidx.recyclerview.widget.RecyclerView$Recycler.tryGetViewHolderForPositionByDeadline(RecyclerView.java:145)
	at androidx.recyclerview.widget.RecyclerView$Recycler.getViewForPosition(RecyclerView.java:1)
	at androidx.recyclerview.widget.LinearLayoutManager$LayoutState.next(LinearLayoutManager.java:8)
	at androidx.recyclerview.widget.LinearLayoutManager.layoutChunk(LinearLayoutManager.java:1)
	at androidx.recyclerview.widget.LinearLayoutManager.fill(LinearLayoutManager.java:12)
	at androidx.recyclerview.widget.LinearLayoutManager.onLayoutChildren(LinearLayoutManager.java:125)
	at androidx.recyclerview.widget.RecyclerView.dispatchLayoutStep2(RecyclerView.java:8)
	at androidx.recyclerview.widget.RecyclerView.dispatchLayout(RecyclerView.java:9)
	at androidx.recyclerview.widget.RecyclerView.onLayout(RecyclerView.java:2)
	at android.view.View.layout(View.java:22228)
	at android.view.ViewGroup.layout(ViewGroup.java:6395)
	at android.widget.FrameLayout.layoutChildren(FrameLayout.java:332)
	at android.widget.FrameLayout.onLayout(FrameLayout.java:270)
	at android.view.View.layout(View.java:22228)
	at android.view.ViewGroup.layout(ViewGroup.java:6395)
	at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1829)
	at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1673)
	at android.widget.LinearLayout.onLayout(LinearLayout.java:1582)
	at android.view.View.layout(View.java:22228)
	at android.view.ViewGroup.layout(ViewGroup.java:6395)
	at android.widget.FrameLayout.layoutChildren(FrameLayout.java:332)
	at android.widget.FrameLayout.onLayout(FrameLayout.java:270)
	at android.view.View.layout(View.java:22228)
	at android.view.ViewGroup.layout(ViewGroup.java:6395)
	at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1829)
	at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1673)
	at android.widget.LinearLayout.onLayout(LinearLayout.java:1582)
	at android.view.View.layout(View.java:22228)
	at android.view.ViewGroup.layout(ViewGroup.java:6395)
	at android.widget.FrameLayout.layoutChildren(FrameLayout.java:332)
	at android.widget.FrameLayout.onLayout(FrameLayout.java:270)
	at android.view.View.layout(View.java:22228)
	at android.view.ViewGroup.layout(ViewGroup.java:6395)
	at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1829)
	at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1673)
	at android.widget.LinearLayout.onLayout(LinearLayout.java:1582)
	at android.view.View.layout(View.java:22228)
	at android.view.ViewGroup.layout(ViewGroup.java:6395)
	at android.widget.FrameLayout.layoutChildren(FrameLayout.java:332)
	at android.widget.FrameLayout.onLayout(FrameLayout.java:270)
	at android.view.View.layout(View.java:22228)
	at android.view.ViewGroup.layout(ViewGroup.java:6395)
	at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1829)
	at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1673)
	at android.widget.LinearLayout.onLayout(LinearLayout.java:1582)
	at android.view.View.layout(View.java:22228)
	at android.view.ViewGroup.layout(ViewGroup.java:6395)
	at android.widget.FrameLayout.layoutChildren(FrameLayout.java:332)
	at android.widget.FrameLayout.onLayout(FrameLayout.java:270)
	at com.android.internal.policy.DecorView.onLayout(DecorView.java:812)
	at android.view.View.layout(View.java:22228)
	at android.view.ViewGroup.layout(ViewGroup.java:6395)
	at android.view.ViewRootImpl.performLayout(ViewRootImpl.java:3314)
	at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2810)
	at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1883)
	at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:8038)
	at android.view.Choreographer$CallbackRecord.run(Choreographer.java:969)
	at android.view.Choreographer.doCallbacks(Choreographer.java:793)
	at android.view.Choreographer.doFrame(Choreographer.java:728)
	at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:954)
	at android.os.Handler.handleCallback(Handler.java:914)
	at android.os.Handler.dispatchMessage(Handler.java:100)
	at android.os.Looper.loop(Looper.java:225)
	at android.app.ActivityThread.main(ActivityThread.java:7573)
	at java.lang.reflect.Method.invoke(Native Method)
	at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:539)
	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:995)

@hwinnemoe
Copy link

hwinnemoe commented Jul 25, 2020

I can reproduce on Nightly 200725 06:01 (Build #22070612) on Android 6.0.1, accessing Search in the Setttings crashes with:

e61ee1fa-fa5e-4f5f-bdd5-7137831ad8c5
java.lang.ClassCastException: android.widget.LinearLayout cannot be cast to androidx.constraintlayout.widget.ConstraintLayout


java.lang.ClassCastException: android.widget.LinearLayout cannot be cast to androidx.constraintlayout.widget.ConstraintLayout
	at org.mozilla.fenix.settings.search.SearchEngineListPreference.makeButtonFromSearchEngine(SearchEngineListPreference.kt:2)
	at org.mozilla.fenix.settings.search.SearchEngineListPreference.access$makeButtonFromSearchEngine(SearchEngineListPreference.kt:1)
	at org.mozilla.fenix.settings.search.SearchEngineListPreference.refreshSearchEngineViews(SearchEngineListPreference.kt:18)
	at org.mozilla.fenix.settings.search.SearchEngineListPreference.reload(SearchEngineListPreference.kt:2)
	at org.mozilla.fenix.settings.search.SearchEngineListPreference.onBindViewHolder(SearchEngineListPreference.kt:3)
	at androidx.preference.PreferenceGroupAdapter.onBindViewHolder(PreferenceGroupAdapter.java:3)
	at androidx.recyclerview.widget.RecyclerView$Adapter.onBindViewHolder(RecyclerView.java:1)
	at androidx.recyclerview.widget.RecyclerView$Adapter.bindViewHolder(RecyclerView.java:6)
	at androidx.recyclerview.widget.RecyclerView$Recycler.tryGetViewHolderForPositionByDeadline(RecyclerView.java:145)
	at androidx.recyclerview.widget.RecyclerView$Recycler.getViewForPosition(RecyclerView.java:1)
	at androidx.recyclerview.widget.LinearLayoutManager$LayoutState.next(LinearLayoutManager.java:8)
	at androidx.recyclerview.widget.LinearLayoutManager.layoutChunk(LinearLayoutManager.java:1)
	at androidx.recyclerview.widget.LinearLayoutManager.fill(LinearLayoutManager.java:12)
	at androidx.recyclerview.widget.LinearLayoutManager.onLayoutChildren(LinearLayoutManager.java:125)
	at androidx.recyclerview.widget.RecyclerView.dispatchLayoutStep2(RecyclerView.java:8)
	at androidx.recyclerview.widget.RecyclerView.dispatchLayout(RecyclerView.java:9)
	at androidx.recyclerview.widget.RecyclerView.onLayout(RecyclerView.java:2)
	at android.view.View.layout(View.java:16722)
	at android.view.ViewGroup.layout(ViewGroup.java:5438)
	at android.widget.FrameLayout.layoutChildren(FrameLayout.java:336)
	at android.widget.FrameLayout.onLayout(FrameLayout.java:273)
	at android.view.View.layout(View.java:16722)
	at android.view.ViewGroup.layout(ViewGroup.java:5438)
	at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1743)
	at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1586)
	at android.widget.LinearLayout.onLayout(LinearLayout.java:1495)
	at android.view.View.layout(View.java:16722)
	at android.view.ViewGroup.layout(ViewGroup.java:5438)
	at android.widget.FrameLayout.layoutChildren(FrameLayout.java:336)
	at android.widget.FrameLayout.onLayout(FrameLayout.java:273)
	at android.view.View.layout(View.java:16722)
	at android.view.ViewGroup.layout(ViewGroup.java:5438)
	at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1743)
	at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1586)
	at android.widget.LinearLayout.onLayout(LinearLayout.java:1495)
	at android.view.View.layout(View.java:16722)
	at android.view.ViewGroup.layout(ViewGroup.java:5438)
	at android.widget.FrameLayout.layoutChildren(FrameLayout.java:336)
	at android.widget.FrameLayout.onLayout(FrameLayout.java:273)
	at android.view.View.layout(View.java:16722)
	at android.view.ViewGroup.layout(ViewGroup.java:5438)
	at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1743)
	at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1586)
	at android.widget.LinearLayout.onLayout(LinearLayout.java:1495)
	at android.view.View.layout(View.java:16722)
	at android.view.ViewGroup.layout(ViewGroup.java:5438)
	at android.widget.FrameLayout.layoutChildren(FrameLayout.java:336)
	at android.widget.FrameLayout.onLayout(FrameLayout.java:273)
	at android.view.View.layout(View.java:16722)
	at android.view.ViewGroup.layout(ViewGroup.java:5438)
	at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1743)
	at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1586)
	at android.widget.LinearLayout.onLayout(LinearLayout.java:1495)
	at android.view.View.layout(View.java:16722)
	at android.view.ViewGroup.layout(ViewGroup.java:5438)
	at android.widget.FrameLayout.layoutChildren(FrameLayout.java:336)
	at android.widget.FrameLayout.onLayout(FrameLayout.java:273)
	at com.android.internal.policy.PhoneWindow$DecorView.onLayout(PhoneWindow.java:2685)
	at android.view.View.layout(View.java:16722)
	at android.view.ViewGroup.layout(ViewGroup.java:5438)
	at android.view.ViewRootImpl.performLayout(ViewRootImpl.java:2175)
	at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1935)
	at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1111)
	at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6017)
	at android.view.Choreographer$CallbackRecord.run(Choreographer.java:858)
	at android.view.Choreographer.doCallbacks(Choreographer.java:670)
	at android.view.Choreographer.doFrame(Choreographer.java:606)
	at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:844)
	at android.os.Handler.handleCallback(Handler.java:739)
	at android.os.Handler.dispatchMessage(Handler.java:95)
	at android.os.Looper.loop(Looper.java:234)
	at android.app.ActivityThread.main(ActivityThread.java:5526)
	at java.lang.reflect.Method.invoke(Native Method)
	at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

This commit b3b7566 introduced a new LinearLayout in the Search Layout with b3b7566#diff-5919d313ccf3173a1143d11a97b75394R5 in order to resolve #12804.

@hkaancaliskan
Copy link

Sorry for this crash, I'm looking for a fix.

@ekager ekager added b:crash Crashes Fenix: should link to Sentry, Crash-Stats or GPlay info and removed needs:triage Issue needs triage labels Jul 25, 2020
ekager pushed a commit that referenced this issue Jul 25, 2020
@ekager ekager added the eng:qa:needed QA Needed label Jul 25, 2020
@kbrosnan kbrosnan changed the title [Bug]Crash Code Report (Always Crash) Crash in [@ java.lang.ClassCastException: at org.mozilla.fenix.settings.search.SearchEngineListPreference.makeButtonFromSearchEngine(SearchEngineListPreference.kt:2)] Jul 27, 2020
@kbrosnan kbrosnan added this to Needs triage in Android: Crash Tracking via automation Jul 27, 2020
@kbrosnan kbrosnan moved this from Needs triage to Top issues in Android: Crash Tracking Jul 27, 2020
@sflorean
Copy link
Contributor

sflorean commented Jul 28, 2020

Verified as fixed on Nightly 7/28 with Xiaomi Redmi Note 8T (Android 9).

Android: Crash Tracking automation moved this from Top issues to Closed Jul 28, 2020
@sflorean sflorean added eng:qa:verified QA Verified and removed eng:qa:needed QA Needed labels Jul 28, 2020
@data-sync-user data-sync-user changed the title Crash in [@ java.lang.ClassCastException: at org.mozilla.fenix.settings.search.SearchEngineListPreference.makeButtonFromSearchEngine(SearchEngineListPreference.kt:2)] FNX3-21976 ⁃ Crash in [@ java.lang.ClassCastException: at org.mozilla.fenix.settings.search.SearchEngineListPreference.makeButtonFromSearchEngine(SearchEngineListPreference.kt:2)] Aug 11, 2020
Android: Crash Tracking automation moved this from Closed to Needs triage Aug 11, 2020
@data-sync-user data-sync-user changed the title FNX3-21976 ⁃ Crash in [@ java.lang.ClassCastException: at org.mozilla.fenix.settings.search.SearchEngineListPreference.makeButtonFromSearchEngine(SearchEngineListPreference.kt:2)] FNX-14071 ⁃ Crash in [@ java.lang.ClassCastException: at org.mozilla.fenix.settings.search.SearchEngineListPreference.makeButtonFromSearchEngine(SearchEngineListPreference.kt:2)] Aug 11, 2020
Android: Crash Tracking automation moved this from Needs triage to Closed Aug 11, 2020
@data-sync-user data-sync-user changed the title FNX-14071 ⁃ Crash in [@ java.lang.ClassCastException: at org.mozilla.fenix.settings.search.SearchEngineListPreference.makeButtonFromSearchEngine(SearchEngineListPreference.kt:2)] FNX2-15554 ⁃ Crash in [@ java.lang.ClassCastException: at org.mozilla.fenix.settings.search.SearchEngineListPreference.makeButtonFromSearchEngine(SearchEngineListPreference.kt:2)] Aug 11, 2020
Android: Crash Tracking automation moved this from Closed to Needs triage Aug 11, 2020
Android: Crash Tracking automation moved this from Needs triage to Closed Aug 12, 2020
@data-sync-user data-sync-user changed the title FNX2-15554 ⁃ Crash in [@ java.lang.ClassCastException: at org.mozilla.fenix.settings.search.SearchEngineListPreference.makeButtonFromSearchEngine(SearchEngineListPreference.kt:2)] Crash in [@ java.lang.ClassCastException: at org.mozilla.fenix.settings.search.SearchEngineListPreference.makeButtonFromSearchEngine(SearchEngineListPreference.kt:2)] May 19, 2022
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
b:crash Crashes Fenix: should link to Sentry, Crash-Stats or GPlay info 🐞 bug Crashes, Something isn't working, .. eng:qa:verified QA Verified
Projects
No open projects
Development

No branches or pull requests

7 participants