TestPlayerRunHelper.PlayerRunResult


public class TestPlayerRunHelper.PlayerRunResult

Known direct subclasses
TestPlayerRunHelper.CompositionPlayerRunResult

A CompositionPlayer specific subclass of PlayerRunResult, giving access to conditions that only make sense for CompositionPlayer.

TestPlayerRunHelper.ExoPlayerRunResult

An ExoPlayer specific subclass of PlayerRunResult, giving access to conditions that only make sense for the ExoPlayer interface.


Intermediate type that allows callers to run the main Looper until certain conditions are met.

If an error occurs while a untilXXX(...) method is waiting for the condition to become true, most methods will throw that error (exceptions to this are documented on specific methods below). Use ignoringNonFatalErrors to ignore non-fatal errors and only fail on fatal playback errors.

Instances of this class should only be used for a single untilXXX() invocation and not be re-used.

Summary

Protected fields

boolean
final boolean
final Player
final boolean
final long

Public methods

TestPlayerRunHelper.PlayerRunResult

Returns a new instance where the untilXXX(...) methods ignore non-fatal errors.

void

Runs tasks of the main Looper until onRenderedFirstFrame is called or an error occurs.

final void
untilLoadingIs(boolean expectedIsLoading)

Runs tasks of the main Looper until isLoading matches the expected value or an error occurs.

void

Runs tasks of the main looper until all pending tasks in targetLooper have been handled and have propagated any updates to the main looper.

final void
untilPlayWhenReadyIs(boolean expectedPlayWhenReady)

Runs tasks of the main Looper until getPlayWhenReady matches the expected value or an error occurs.

PlaybackException

Runs tasks of the main Looper until a player error occurs.

final void
untilPlayingAdIs(boolean expectedIsPlayingAd)

Runs tasks of the main Looper until isPlayingAd ()} matches the expected value or an error occurs.

final void

Runs tasks of the main Looper until onPositionDiscontinuity is called with the specified Player.DiscontinuityReason or an error occurs.

final void
untilState(@Player.State int expectedState)

Runs tasks of the main Looper until getPlaybackState matches the expected state or an error occurs.

final Timeline

Runs tasks of the main Looper until a timeline change or an error occurs.

final void
untilTimelineChangesTo(Timeline expectedTimeline)

Runs tasks of the main Looper until getCurrentTimeline matches the expected timeline or an error occurs.

TestPlayerRunHelper.PlayerRunResult
withTimeoutMs(long timeoutMs)

Returns a new instance where the untilXXX(...) methods use the given timeout.

Protected methods

final void

Runs the main Looper until predicate returns true or an error occurs.

Protected fields

hasBeenUsed

protected boolean hasBeenUsed

playBeforeWaiting

protected final boolean playBeforeWaiting

player

protected final Player player

throwNonFatalErrors

protected final boolean throwNonFatalErrors

timeoutMs

protected final long timeoutMs

Public methods

ignoringNonFatalErrors

public TestPlayerRunHelper.PlayerRunResult ignoringNonFatalErrors()

Returns a new instance where the untilXXX(...) methods ignore non-fatal errors.

A fatal error is defined as an error that is passed to onPlayerError and results in the player transitioning to STATE_IDLE. A non-fatal error is defined as an error that is passed to any other callback (e.g. onLoadError).

untilFirstFrameIsRendered

public void untilFirstFrameIsRendered()

Runs tasks of the main Looper until onRenderedFirstFrame is called or an error occurs.

Throws
androidx.media3.common.PlaybackException

If a playback error occurs.

java.lang.IllegalStateException

If non-fatal playback errors occur, and aren't ignored (the non-fatal exceptions will be attached with addSuppressed).

java.util.concurrent.TimeoutException

If the timeout is exceeded. The timeout is DEFAULT_TIMEOUT_MS by default, or a specific value if this instance is created via withTimeoutMs.

untilLoadingIs

public final void untilLoadingIs(boolean expectedIsLoading)

Runs tasks of the main Looper until isLoading matches the expected value or an error occurs.

Throws
androidx.media3.common.PlaybackException

If a playback error occurs.

java.lang.IllegalStateException

If non-fatal playback errors occur, and aren't ignored (the non-fatal exceptions will be attached with addSuppressed).

java.util.concurrent.TimeoutException

If the timeout is exceeded. The timeout is DEFAULT_TIMEOUT_MS by default, or a specific value if this instance is created via withTimeoutMs.

untilPendingCommandsAreFullyHandled

public void untilPendingCommandsAreFullyHandled(Clock clock, Looper targetLooper)

Runs tasks of the main looper until all pending tasks in targetLooper have been handled and have propagated any updates to the main looper.

Both fatal and non-fatal errors are always ignored.

Parameters
Clock clock

The player's Clock.

Looper targetLooper

The looper whose pending tasks to handle.

Throws
java.util.concurrent.TimeoutException

If the timeout is exceeded. The timeout is DEFAULT_TIMEOUT_MS by default, or a specific value if this instance is created via withTimeoutMs.

untilPlayWhenReadyIs

public final void untilPlayWhenReadyIs(boolean expectedPlayWhenReady)

Runs tasks of the main Looper until getPlayWhenReady matches the expected value or an error occurs.

Throws
androidx.media3.common.PlaybackException

If a playback error occurs.

java.lang.IllegalStateException

If non-fatal playback errors occur, and aren't ignored (the non-fatal exceptions will be attached with addSuppressed).

java.util.concurrent.TimeoutException

If the timeout is exceeded. The timeout is DEFAULT_TIMEOUT_MS by default, or a specific value if this instance is created via withTimeoutMs.

untilPlayerError

public PlaybackException untilPlayerError()

Runs tasks of the main Looper until a player error occurs.

Non-fatal errors are always ignored.

Returns
PlaybackException

The raised PlaybackException.

Throws
java.util.concurrent.TimeoutException

If the timeout is exceeded. The timeout is DEFAULT_TIMEOUT_MS by default, or a specific value if this instance is created via withTimeoutMs.

untilPlayingAdIs

public final void untilPlayingAdIs(boolean expectedIsPlayingAd)

Runs tasks of the main Looper until isPlayingAd ()} matches the expected value or an error occurs.

Throws
androidx.media3.common.PlaybackException

If a playback error occurs.

java.lang.IllegalStateException

If non-fatal playback errors occur, and aren't ignored (the non-fatal exceptions will be attached with addSuppressed).

java.util.concurrent.TimeoutException

If the timeout is exceeded. The timeout is DEFAULT_TIMEOUT_MS by default, or a specific value if this instance is created via withTimeoutMs.

untilPositionDiscontinuityWithReason

public final void untilPositionDiscontinuityWithReason(
    @Player.DiscontinuityReason int expectedReason
)

Runs tasks of the main Looper until onPositionDiscontinuity is called with the specified Player.DiscontinuityReason or an error occurs.

Throws
androidx.media3.common.PlaybackException

If a playback error occurs.

java.lang.IllegalStateException

If non-fatal playback errors occur, and aren't ignored (the non-fatal exceptions will be attached with addSuppressed).

java.util.concurrent.TimeoutException

If the timeout is exceeded. The timeout is DEFAULT_TIMEOUT_MS by default, or a specific value if this instance is created via withTimeoutMs.

untilState

public final void untilState(@Player.State int expectedState)

Runs tasks of the main Looper until getPlaybackState matches the expected state or an error occurs.

Throws
androidx.media3.common.PlaybackException

If a fatal playback error occurs.

java.lang.IllegalStateException

If non-fatal playback errors occur, and aren't ignored (the non-fatal exceptions will be attached with addSuppressed).

java.util.concurrent.TimeoutException

If the timeout is exceeded. The timeout is DEFAULT_TIMEOUT_MS by default, or a specific value if this instance is created via withTimeoutMs.

untilTimelineChanges

public final Timeline untilTimelineChanges()

Runs tasks of the main Looper until a timeline change or an error occurs.

Throws
androidx.media3.common.PlaybackException

If a playback error occurs.

java.lang.IllegalStateException

If non-fatal playback errors occur, and aren't ignored (the non-fatal exceptions will be attached with addSuppressed).

java.util.concurrent.TimeoutException

If the timeout is exceeded. The timeout is DEFAULT_TIMEOUT_MS by default, or a specific value if this instance is created via withTimeoutMs.

untilTimelineChangesTo

public final void untilTimelineChangesTo(Timeline expectedTimeline)

Runs tasks of the main Looper until getCurrentTimeline matches the expected timeline or an error occurs.

Throws
androidx.media3.common.PlaybackException

If a playback error occurs.

java.lang.IllegalStateException

If non-fatal playback errors occur, and aren't ignored (the non-fatal exceptions will be attached with addSuppressed).

java.util.concurrent.TimeoutException

If the timeout is exceeded. The timeout is DEFAULT_TIMEOUT_MS by default, or a specific value if this instance is created via withTimeoutMs.

withTimeoutMs

public TestPlayerRunHelper.PlayerRunResult withTimeoutMs(long timeoutMs)

Returns a new instance where the untilXXX(...) methods use the given timeout.

If not set, the default timeout is DEFAULT_TIMEOUT_MS.

Parameters
long timeoutMs

The timeout in milliseconds.

Protected methods

runUntil

protected final void runUntil(Supplier<Boolean> predicate)

Runs the main Looper until predicate returns true or an error occurs.