java.lang.RuntimeException: java.util.concurrent.ExecutionException: java.lang.IllegalArgumentException: Detected multithreaded access to SnapshotStateObserver: previousThreadId=176), currentThread={id=2, name=main}.
Categories
(Firefox for Android :: Accounts and Sync, defect, P3)
Tracking
()
| Tracking | Status | |
|---|---|---|
| firefox141 | --- | unaffected |
| firefox142 | --- | unaffected |
| firefox143 | --- | wontfix |
| firefox144 | --- | affected |
| firefox145 | --- | affected |
| firefox146 | --- | affected |
| firefox147 | --- | affected |
People
(Reporter: ajoltan, Unassigned)
Details
Firebase Test Run:
httpsOnlyModeMenuItemsTest
Firebase link
verifySponsoredShortcutsDetailsTest
Firebase link
Stacktrace:
java.lang.RuntimeException: java.util.concurrent.ExecutionException: java.lang.IllegalArgumentException: Detected multithreaded access to SnapshotStateObserver: previousThreadId=176), currentThread={id=2, name=main}. Note that observation on multiple threads in layout/draw is not supported. Make sure your measure/layout/draw for each Owner (AndroidComposeView) is executed on the same thread.
at androidx.test.espresso.Espresso.onIdle(Espresso.java:357)
at androidx.test.espresso.Espresso.onIdle(Espresso.java:378)
at androidx.compose.ui.test.EspressoLink_androidKt.runEspressoOnIdle(EspressoLink.android.kt:88)
at androidx.compose.ui.test.EspressoLink.runUntilIdle(EspressoLink.android.kt:82)
at androidx.compose.ui.test.AndroidComposeUiTestEnvironment.waitForNextChoreographerFrame(ComposeUiTest.android.kt:402)
at androidx.compose.ui.test.AndroidComposeUiTestEnvironment.waitForIdle(ComposeUiTest.android.kt:385)
at androidx.compose.ui.test.AndroidComposeUiTestEnvironment.access$waitForIdle(ComposeUiTest.android.kt:235)
at androidx.compose.ui.test.AndroidComposeUiTestEnvironment$AndroidTestOwner.getRoots(ComposeUiTest.android.kt:603)
at androidx.compose.ui.test.TestOwnerKt.getAllSemanticsNodes(TestOwner.kt:81)
at androidx.compose.ui.test.TestOwnerKt.getAllSemanticsNodes$default(TestOwner.kt:74)
at androidx.compose.ui.test.SemanticsNodeInteractionCollection.fetchSemanticsNodes(SemanticsNodeInteraction.kt:249)
at androidx.compose.ui.test.SemanticsNodeInteractionCollection.fetchSemanticsNodes$default(SemanticsNodeInteraction.kt:245)
at androidx.compose.ui.test.ComposeUiTestKt$waitUntilAtLeastOneExists$1.invoke(ComposeUiTest.kt:230)
at androidx.compose.ui.test.ComposeUiTestKt$waitUntilAtLeastOneExists$1.invoke(ComposeUiTest.kt:229)
at androidx.compose.ui.test.AndroidComposeUiTestEnvironment$AndroidComposeUiTestImpl.waitUntil(ComposeUiTest.android.kt:497)
at androidx.compose.ui.test.ComposeUiTestKt.waitUntilAtLeastOneExists(ComposeUiTest.kt:229)
at androidx.compose.ui.test.junit4.AndroidComposeTestRule.waitUntilAtLeastOneExists(AndroidComposeTestRule.android.kt:355)
at org.mozilla.fenix.ui.robots.HomeScreenRobot.verifyExistingTopSitesList(HomeScreenRobot.kt:269)
at org.mozilla.fenix.ui.SponsoredShortcutsTest.verifySponsoredShortcutsDetailsTest$lambda$17(SponsoredShortcutsTest.kt:107)
at org.mozilla.fenix.ui.SponsoredShortcutsTest.$r8$lambda$d13cIZi4TEVbzkIWePZLOqb8rPo(Unknown Source:0)
at org.mozilla.fenix.ui.SponsoredShortcutsTest$$ExternalSyntheticLambda28.invoke(D8$$SyntheticClass:0)
at org.mozilla.fenix.ui.robots.HomeScreenRobotKt.homeScreen(HomeScreenRobot.kt:886)
at org.mozilla.fenix.ui.SponsoredShortcutsTest.verifySponsoredShortcutsDetailsTest(SponsoredShortcutsTest.kt:106)
... 56 trimmed
Caused by: java.util.concurrent.ExecutionException: java.lang.IllegalArgumentException: Detected multithreaded access to SnapshotStateObserver: previousThreadId=176), currentThread={id=2, name=main}. Note that observation on multiple threads in layout/draw is not supported. Make sure your measure/layout/draw for each Owner (AndroidComposeView) is executed on the same thread.
at java.util.concurrent.FutureTask.report(FutureTask.java:122)
at java.util.concurrent.FutureTask.get(FutureTask.java:191)
at androidx.test.espresso.Espresso.onIdle(Espresso.java:349)
... 79 more
Caused by: java.lang.IllegalArgumentException: Detected multithreaded access to SnapshotStateObserver: previousThreadId=176), currentThread={id=2, name=main}. Note that observation on multiple threads in layout/draw is not supported. Make sure your measure/layout/draw for each Owner (AndroidComposeView) is executed on the same thread.
at androidx.compose.runtime.PreconditionsKt.throwIllegalArgumentException(Preconditions.kt:26)
at androidx.compose.runtime.snapshots.SnapshotStateObserver.observeReads(SnapshotStateObserver.kt:649)
at androidx.compose.ui.node.OwnerSnapshotObserver.observeReads$ui_release(OwnerSnapshotObserver.kt:124)
at androidx.compose.ui.node.NodeCoordinator$drawBlock$1.invoke(NodeCoordinator.kt:480)
at androidx.compose.ui.node.NodeCoordinator$drawBlock$1.invoke(NodeCoordinator.kt:476)
at androidx.compose.ui.platform.GraphicsLayerOwnerLayer$recordLambda$1.invoke(GraphicsLayerOwnerLayer.android.kt:261)
at androidx.compose.ui.platform.GraphicsLayerOwnerLayer$recordLambda$1.invoke(GraphicsLayerOwnerLayer.android.kt:259)
at androidx.compose.ui.graphics.layer.GraphicsLayer.drawWithChildTracking(AndroidGraphicsLayer.android.kt:443)
at androidx.compose.ui.graphics.layer.GraphicsLayer.access$drawWithChildTracking(AndroidGraphicsLayer.android.kt:56)
at androidx.compose.ui.graphics.layer.GraphicsLayer$clipDrawBlock$1.invoke(AndroidGraphicsLayer.android.kt:73)
at androidx.compose.ui.graphics.layer.GraphicsLayer$clipDrawBlock$1.invoke(AndroidGraphicsLayer.android.kt:68)
at androidx.compose.ui.graphics.layer.GraphicsLayerV29.record(GraphicsLayerV29.android.kt:251)
at androidx.compose.ui.graphics.layer.GraphicsLayer.recordInternal(AndroidGraphicsLayer.android.kt:436)
at androidx.compose.ui.graphics.layer.GraphicsLayer.record-mL-hObY(AndroidGraphicsLayer.android.kt:432)
at androidx.compose.ui.platform.GraphicsLayerOwnerLayer.updateDisplayList(GraphicsLayerOwnerLayer.android.kt:254)
at androidx.compose.ui.platform.AndroidComposeView.dispatchDraw(AndroidComposeView.android.kt:1913)
at android.view.View.draw(View.java:23892)
at android.view.View.updateDisplayListIfDirty(View.java:22756)
at android.view.ViewGroup.recreateChildDisplayList(ViewGroup.java:4540)
at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:4513)
at android.view.View.updateDisplayListIfDirty(View.java:22712)
at android.view.ViewGroup.recreateChildDisplayList(ViewGroup.java:4540)
at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:4513)
at android.view.View.updateDisplayListIfDirty(View.java:22712)
at android.view.ViewGroup.recreateChildDisplayList(ViewGroup.java:4540)
at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:4513)
at android.view.View.updateDisplayListIfDirty(View.java:22712)
at android.view.ViewGroup.recreateChildDisplayList(ViewGroup.java:4540)
at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:4513)
at android.view.View.updateDisplayListIfDirty(View.java:22712)
at android.view.ViewGroup.recreateChildDisplayList(ViewGroup.java:4540)
at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:4513)
at android.view.View.updateDisplayListIfDirty(View.java:22712)
at android.view.ViewGroup.recreateChildDisplayList(ViewGroup.java:4540)
at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:4513)
at android.view.View.updateDisplayListIfDirty(View.java:22712)
at android.view.ViewGroup.recreateChildDisplayList(ViewGroup.java:4540)
at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:4513)
at android.view.View.updateDisplayListIfDirty(View.java:22712)
at android.view.ViewGroup.recreateChildDisplayList(ViewGroup.java:4540)
at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:4513)
at android.view.View.updateDisplayListIfDirty(View.java:22712)
at android.view.ViewGroup.recreateChildDisplayList(ViewGroup.java:4540)
at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:4513)
at android.view.View.updateDisplayListIfDirty(View.java:22712)
at android.view.ViewGroup.recreateChildDisplayList(ViewGroup.java:4540)
at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:4513)
at android.view.View.updateDisplayListIfDirty(View.java:22712)
at android.view.ViewGroup.recreateChildDisplayList(ViewGroup.java:4540)
at android.view.ViewGroup.dispatchGetDisplayList(ViewGroup.java:4513)
at android.view.View.updateDisplayListIfDirty(View.java:22712)
at android.view.ThreadedRenderer.updateViewTreeDisplayList(ThreadedRenderer.java:694)
at android.view.ThreadedRenderer.updateRootDisplayList(ThreadedRenderer.java:700)
at android.view.ThreadedRenderer.draw(ThreadedRenderer.java:798)
at android.view.ViewRootImpl.draw(ViewRootImpl.java:4939)
at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:4643)
at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:3822)
at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:2465)
at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:9305)
at android.view.Choreographer$CallbackRecord.run(Choreographer.java:1339)
at android.view.Choreographer$CallbackRecord.run(Choreographer.java:1348)
at android.view.Choreographer.doCallbacks(Choreographer.java:952)
at android.view.Choreographer.doFrame(Choreographer.java:882)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:1322)
at android.os.Handler.handleCallback(Handler.java:958)
at android.os.Handler.dispatchMessage(Handler.java:99)
at androidx.test.espresso.base.Interrogator.loopAndInterrogate(Interrogator.java:156)
at androidx.test.espresso.base.UiControllerImpl.loopUntil(UiControllerImpl.java:510)
at androidx.test.espresso.base.UiControllerImpl.loopMainThreadUntilIdle(UiControllerImpl.java:433)
at androidx.test.espresso.Espresso.lambda$onIdle$2(Espresso.java:340)
at androidx.test.espresso.Espresso$$ExternalSyntheticLambda1.call(D8$$SyntheticClass:0)
at java.util.concurrent.FutureTask.run(FutureTask.java:264)
at android.os.Handler.handleCallback(Handler.java:958)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loopOnce(Looper.java:205)
at android.os.Looper.loop(Looper.java:294)
at android.app.ActivityThread.main(ActivityThread.java:8177)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:552)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:971)
Build: 7/22 mozilla-central
Comment 1•1 month ago
|
||
► 9/21 mozilla-central Firebase link
Comment 2•1 month ago
|
||
► 9/22 autoland verifyManageAddressesPromptOptionTest Firebase link
Comment 3•1 month ago
•
|
||
► 9/24 autoland verifyAddBookmarkButtonTest legacy-arm: Firebase link
► 9/25 autoland verifyOpenLinkInAppContextMenuOptionTest Firebase link
Updated•1 month ago
|
Comment 4•1 month ago
•
|
||
► 9/25 mozilla-beta verifyTheMainMenuRefreshButtonFromCustomTabTest Firebase link
► 9/25 mozilla-beta verifyOpenInFirefoxMainMenuTest Firebase link
► 9/26 mozilla-beta verifyQRScanningCameraAccessDialogTest Firebase link
► 9/26 mozilla-beta verifyTheBrokenSiteFormIsEmptyWithoutSubmittingThePreviousOneTest Firebase link
Comment 5•1 month ago
•
|
||
► 10/01 mozilla-beta Firebase link
► 10/01 mozilla-beta Firebase link
► 10/02 autoland Firebase link
| Reporter | ||
Comment 6•1 month ago
•
|
||
► 10/04 mozilla-central
verifyTabsSearchItemsTest Firebase link
fileDeletedFromStorageIsDeletedEverywhereTest Firebase link
► 10/07 mozilla-central
verifyClearSearchButtonTest Firebase link
Comment 7•1 month ago
•
|
||
► 10/07 mozilla-central verifyClearSearchButtonTest Firebase link
► 10/07 autoland searchLoginsByUsernameTest Firebase link
| Reporter | ||
Comment 8•1 month ago
|
||
► 10/13 autoland verifyTheSettingsMainMenuItemTest Firebase link
| Reporter | ||
Comment 9•1 month ago
•
|
||
► 10/16 autoland
verifyTheHomePageSettingsMenuItemTest Firebase link
verifyShowSearchSuggestionsToggleTest Firebase link
Comment 10•25 days ago
•
|
||
► 10/22 autoland enablingETPOnAWebsiteRemovesItFromTheExceptionListTest Firebase link
► 10/22 autoland openSponsoredShortcutsSettingsOptionTest Firebase link
► 10/21 mozilla-beta allFilesAppearInDownloadsMenuTest Firebase link
► 10/21 mozilla-beta switchDesktopSiteModeOnOffTest Firebase link
► 10/21 mozilla-beta deleteBrowsingDataOnQuitSettingTest Firebase link
► 10/21 mozilla-beta httpsOnlyModeEnabledInNormalBrowsingTest Firebase link
Comment 11•23 days ago
•
|
||
► 10/23 mozilla-beta verifyTabsTrayGridView Firebase link
► 10/23 mozilla-beta verifyLastUsedLoginSortingOptionTest Firebase link
► 10/23 mozilla-beta verifyClearCookiesFromQuickSettingsTest Firebase link
► 10/23 mozilla-beta verifyCopyImageLocationContextMenuOptionTest Firebase link
► 10/23 mozilla-release deleteRecentlyClosedTabsItemTest Firebase link
► 10/23 mozilla-release verifyBookmarksSearchItemsTest Firebase link
Comment 12•6 days ago
•
|
||
► 11/09 autoland navigateBackAndForwardTest legacy-arm: Firebase link
► 11/10 autoland closeTabFromCrashedTabReporterTest Firebase link
► 11/08 autoland findInPageTest Firebase link
► 11/08 mozilla-beta openLoginWebsiteInBrowserTest Firebase link
► 11/07 autoland verifyThatTheBrokenSiteFormInfoPersistsTest Firebase link
Comment 13•5 days ago
|
||
► 11/11 mozilla-beta verifyPDFFileIsOpenedInTheSameTabTest Firebase link
Comment 14•4 days ago
•
|
||
► 11/12 mozilla-beta verifyBookmarksSearchForBookmarkedItemsTest Firebase link
► 11/12 mozilla-central verifyCopyUrlBarTextSelectionOptionTest Firebase link
► 11/12 mozilla-central verifyInsecurePageConnectionFromQuickSettingsWithNoTrackersInCustomTabsTest Firebase link
Comment 15•3 days ago
•
|
||
► 11/13 mozilla-central verifyOpenLinkInAppContextMenuOptionTest Firebase link
► 11/13 verifySiteSettingsSectionTest experimental-arm: mozilla-central Firebase link
Comment 16•2 days ago
•
|
||
► 11/14 autoland verifyTheBookmarksMainMenuItemTest Firebase link
► 11/13 verifyClearCookiesFromQuickSettingsTest mozilla-beta Firebase link
► 11/14 mozilla-beta verifyCreditCardsSectionTest Firebase link
Description
•