package com.google.android.apps.common.testing.testrunner;
import android.app.Activity;
import java.util.Collection;
/**
* Interface for tests to use when they need to query the activity lifecycle state.
*
* Activity lifecycle changes occur only on the UI thread - therefore listeners registered with
* an ActivityLifecycleMonitor should expect to be invoked on the UI thread. The direct query
* methods can only be called on the UI thread because otherwise they would not be able to return
* consistent responses.
* <p>
* Retrieve instances of the monitor thru ActivityLifecycleMonitorRegistry.
* </p>
* <p>
* Detecting these lifecycle states requires support from Instrumentation, therefore do not expect
* an instance to be present under any arbitary instrumentation.
* </p>
*/
public interface ActivityLifecycleMonitor {
/**
* Adds a new callback that will be notified when lifecycle changes occur.
* <p>
* Implementors will not hold a strong ref to the callback, the code which registers callbacks
* is responsible for this. Code which registers callbacks should responsibly
* remove their callback when it is no longer needed.
* </p>
* <p>
* Callbacks are executed on the main thread of the application, and should take care not to
* block or otherwise perform expensive operations as it will directly impact the application.
* </p>
*
* @param callback an ActivityLifecycleCallback
*/
void addLifecycleCallback(ActivityLifecycleCallback callback);
/**
* Removes a previously registered lifecycle callback.
*/
void removeLifecycleCallback(ActivityLifecycleCallback callback);
/**
* Returns the current lifecycle stage of a given activity.
*
* This method can only return a consistant and correct answer
* from the main thread, therefore callers should always invoke
* it from the main thread and implementors are free to throw an
* exception if the call is not made on the main thread.
*
* Implementors should ensure this method returns a consistant response if called from a
* lifecycle callback also registered with this monitor (eg: it would be horriblely wrong if a
* callback sees PAUSED and calls this method with the same activity and gets RESUMED.
*
* @param activity an activity in this application.
* @return the lifecycle stage this activity is in.
* @throws IllegalArgumentException if activity is unknown to the monitor.
* @throws NullPointerException if activity is null.
* @throws IllegalStateException if called off the main thread.
*/
Stage getLifecycleStageOf(Activity activity);
/**
* Returns all activities in a given stage of their lifecycle.
* <p>
* This method can only return a consistant and correct answer from the main thread, therefore
* callers should always invoke it from the main thread and implementors are free to throw an
* exception if the call is not made on the main thread.
* </p>
* <p>
* Implementors should ensure this method returns a consistant response if called from a
* lifecycle callback also registered with this monitor (eg: it would be horriblely wrong if a
* callback sees PAUSED and calls this method with the PAUSED and does not see its activity in
* the response.
* </p>
*
* <p>
* Callers should be aware that the monitor implementation may not hold strong references to the
* Activities in the application. Therefore stages which are considered end stages or eligible for
* garbage collection on low memory situations may not return an instance of a particular activity
* if it has been garbage collected.
*
* @param stage the stage to query for.
* @return a snapshot Collection of activities in the given stage. This collection may be empty.
* @throws IllegalStateException if called from outside the main thread.
*/
Collection<Activity> getActivitiesInStage(Stage stage);
}