Class ShadowPausedLooper
and @link
 LooperMode.Mode.INSTRUMENTATION_TEST.
 This shadow differs from the legacy ShadowLegacyLooper in the following ways:\ - Has
 no connection to Scheduler. Its APIs are standalone - The main
 looper is always paused in PAUSED MODE but can be unpaused in INSTRUMENTATION_TEST mode. When a
 looper is paused, posted messages to it are not executed unless idle() is called. - Just
 like in real Android, each looper has its own thread, and posted tasks get executed in that
 thread. - - There is only a single SystemClock value that all loopers read from. Unlike
 legacy behavior where each Scheduler kept their own clock value.
 
This class should not be used directly; use ShadowLooper instead.
- 
Nested Class SummaryNested classes/interfaces inherited from class org.robolectric.shadows.ShadowLooperShadowLooper.Picker
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected void__constructor__(boolean quitAllowed) protected static Collection<Looper>Returns theSchedulerthat is being used to manage the enqueued tasks.booleanhasQuit()voididle()Executes all posted tasks scheduled before or at the current time.voididleConstantly(boolean shouldIdleConstantly) voidAdvances the system clock by the given time, then executes all posted tasks scheduled before or at the given time.voidHelper method to selectively call idle() only if LooperMode is PAUSED.booleanisIdle()Returns true if there are no pending tasks scheduled to be executed before current time.booleanisPaused()protected static voidloop()Shadow loop to handle uncaught exceptions.voidpause()Pause the looper.voidpoll(long timeout) Polls the message queue waiting until a message is posted to the head of the queue.booleanEnqueue a task to be run later.booleanpostAtFrontOfQueue(Runnable runnable) Enqueue a task to be run ahead of all other delayed tasks.voidPosts the runnable to the looper and idles until the runnable has been run.protected static voidprotected voidquit()protected voidvoidvoidreset()Causes all enqueued tasks to be discarded, and pause state to be resetstatic voidvoidOnly supported forLooperMode.Mode.LEGACY.voidCauses only one of the nextRunnables that have been scheduled to run while advancing the clock to its start time.voidRuns the current task with the looper paused.voidvoidCauses the nextRunnable(s) that have been scheduled to run while advancing the clock to its start time.static voidsetIgnoreUncaughtExceptions(boolean shouldIgnore) Deprecated.this method only exists to accommodate legacy tests with preexisting issues.booleansetPaused(boolean shouldPause) Control the paused state of the Looper.voidunPause()Not supported for the main Looper inLooperMode.Mode.PAUSED.Methods inherited from class org.robolectric.shadows.ShadowLooperassertLooperMode, clearLooperMode, getAllLoopers, getLooperForThread, getShadowMainLooper, idle, idle, idleFor, idleMainLooper, idleMainLooper, idleMainLooper, idleMainLooperConstantly, looperMode, pauseLooper, pauseMainLooper, resetThreadLoopers, runMainLooperOneTask, runMainLooperToNextTask, runUiThreadTasks, runUiThreadTasksIncludingDelayedTasks, shadowMainLooper, unPauseLooper, unPauseMainLooper
- 
Constructor Details- 
ShadowPausedLooperpublic ShadowPausedLooper()
 
- 
- 
Method Details- 
__constructor__
- 
getLoopers
- 
quitUncheckedpublic void quitUnchecked()- Specified by:
- quitUncheckedin class- ShadowLooper
 
- 
hasQuitpublic boolean hasQuit()- Specified by:
- hasQuitin class- ShadowLooper
 
- 
idlepublic void idle()Description copied from class:ShadowLooperExecutes all posted tasks scheduled before or at the current time.- Specified by:
- idlein class- ShadowLooper
 
- 
idleForDescription copied from class:ShadowLooperAdvances the system clock by the given time, then executes all posted tasks scheduled before or at the given time.- Specified by:
- idleForin class- ShadowLooper
 
- 
isIdlepublic boolean isIdle()Description copied from class:ShadowLooperReturns true if there are no pending tasks scheduled to be executed before current time.- Specified by:
- isIdlein class- ShadowLooper
 
- 
unPausepublic void unPause()Description copied from class:ShadowLooperNot supported for the main Looper inLooperMode.Mode.PAUSED.- Specified by:
- unPausein class- ShadowLooper
 
- 
pausepublic void pause()Description copied from class:ShadowLooperPause the looper.Has no practical effect for realistic looper, since it is always paused. - Specified by:
- pausein class- ShadowLooper
 
- 
isPausedpublic boolean isPaused()- Specified by:
- isPausedin class- ShadowLooper
 
- 
setPausedpublic boolean setPaused(boolean shouldPause) Description copied from class:ShadowLooperControl the paused state of the Looper.Not supported for the main Looper in LooperMode.Mode.PAUSED.- Specified by:
- setPausedin class- ShadowLooper
 
- 
resetSchedulerpublic void resetScheduler()Description copied from class:ShadowLooperOnly supported forLooperMode.Mode.LEGACY.- Specified by:
- resetSchedulerin class- ShadowLooper
 
- 
resetpublic void reset()Description copied from class:ShadowLooperCauses all enqueued tasks to be discarded, and pause state to be reset- Specified by:
- resetin class- ShadowLooper
 
- 
idleIfPausedpublic void idleIfPaused()Description copied from class:ShadowLooperHelper method to selectively call idle() only if LooperMode is PAUSED.Intended for backwards compatibility, to avoid changing behavior for tests still using LEGACY LooperMode. - Specified by:
- idleIfPausedin class- ShadowLooper
 
- 
idleConstantlypublic void idleConstantly(boolean shouldIdleConstantly) - Specified by:
- idleConstantlyin class- ShadowLooper
 
- 
runToEndOfTaskspublic void runToEndOfTasks()Description copied from class:ShadowLooperCauses all of theRunnables that have been scheduled to run while advancing the clock to the start time of the last scheduledRunnable.- Specified by:
- runToEndOfTasksin class- ShadowLooper
 
- 
runToNextTaskpublic void runToNextTask()Description copied from class:ShadowLooperCauses the nextRunnable(s) that have been scheduled to run while advancing the clock to its start time. If more than oneRunnableis scheduled to run at this time then they will all be run.- Specified by:
- runToNextTaskin class- ShadowLooper
 
- 
runOneTaskpublic void runOneTask()Description copied from class:ShadowLooperCauses only one of the nextRunnables that have been scheduled to run while advancing the clock to its start time. Only oneRunnablewill run even if more than one has been scheduled to run at the same time.- Specified by:
- runOneTaskin class- ShadowLooper
 
- 
postDescription copied from class:ShadowLooperEnqueue a task to be run later.- Specified by:
- postin class- ShadowLooper
- Parameters:
- runnable- the task to be run
- delayMillis- how many milliseconds into the (virtual) future to run it
- Returns:
- true if the runnable is enqueued
- See Also:
 
- 
postAtFrontOfQueueDescription copied from class:ShadowLooperEnqueue a task to be run ahead of all other delayed tasks.- Specified by:
- postAtFrontOfQueuein class- ShadowLooper
- Parameters:
- runnable- the task to be run
- Returns:
- true if the runnable is enqueued
- See Also:
 
- 
postSyncPosts the runnable to the looper and idles until the runnable has been run. Generally clients should prefer to useInstrumentation.runOnMainSync(Runnable), which will reraise underlying runtime exceptions to the caller.
- 
runPausedDescription copied from class:ShadowLooperRuns the current task with the looper paused.When LooperMode is PAUSED, this will execute all pending tasks scheduled before the current time. - Specified by:
- runPausedin class- ShadowLooper
 
- 
pollpublic void poll(long timeout) Polls the message queue waiting until a message is posted to the head of the queue. This will suspend the thread until a new message becomes available. Returns immediately if the queue is not idle. There's no guarantee that the message queue will not still be idle when returning, but if the message queue becomes not idle it will return immediately.This method is only applicable for the main looper's queue when called on the main thread, as the main looper in Robolectric is processed manually (it doesn't loop)--looper threads are using the native polling of their loopers. Throws an exception if called for another looper's queue. Non-main thread loopers should use unPause().This should be used with care, it can be used to suspend the main (i.e. test) thread while worker threads perform some work, and then resumed by posting to the main looper. Used in a loop to wait on some condition it can process messages on the main looper, simulating the behavior of the real looper, for example: while (!condition) { shadowMainLooper.poll(timeout); shadowMainLooper.idle(); }Beware though that a message must be posted to the main thread after the condition is satisfied, or the condition satisfied while idling the main thread, otherwise the main thread will continue to be suspended until the timeout. - Parameters:
- timeout- Timeout in milliseconds, the maximum time to wait before returning, or 0 to wait indefinitely,
 
- 
getNextScheduledTaskTime- Specified by:
- getNextScheduledTaskTimein class- ShadowLooper
- Returns:
- the scheduled time of the next posted task; Duration.ZERO if there is no currently scheduled task.
 
- 
getLastScheduledTaskTime- Specified by:
- getLastScheduledTaskTimein class- ShadowLooper
- Returns:
- the scheduled time of the last posted task; Duration.ZERO 0 if there is no currently scheduled task.
 
- 
resetLoopers
- 
prepareMainLooper
- 
quit
- 
quitSafely
- 
getSchedulerDescription copied from class:ShadowLooperReturns theSchedulerthat is being used to manage the enqueued tasks. This scheduler is managed by the Looper's associated queue.Only supported for LooperMode.Mode.LEGACY.- Specified by:
- getSchedulerin class- ShadowLooper
- Returns:
- the Schedulerthat is being used to manage the enqueued tasks.
 
- 
setIgnoreUncaughtExceptionsDeprecated.this method only exists to accommodate legacy tests with preexisting issues. Silently discarding exceptions is not recommended, and can lead to deadlocks.By default Robolectric will put Loopers that throw uncaught exceptions in their loop method into an error state, where any future posting to the looper's queue will throw an error.This API allows you to disable this behavior. Note this is a permanent setting - it is not reset between tests. 
- 
loopShadow loop to handle uncaught exceptions. Without this logic an uncaught exception on a looper thread will cause idle() to deadlock.
 
-