Instrumentation
public
class
Instrumentation
extends Object
java.lang.Object | |
↳ | android.app.Instrumentation |
Base class for implementing application instrumentation code. When running with instrumentation turned on, this class will be instantiated for you before any of the application code, allowing you to monitor all of the interaction the system has with the application. An Instrumentation implementation is described to the system through an AndroidManifest.xml's <instrumentation> tag.
Summary
Nested classes | |
---|---|
class |
Instrumentation.ActivityMonitor
Information about a particular kind of Intent that is being monitored. |
class |
Instrumentation.ActivityResult
Description of a Activity execution result to return to the original activity. |
Constants | |
---|---|
String |
REPORT_KEY_IDENTIFIER
If included in the status or final bundle sent to an IInstrumentationWatcher, this key identifies the class that is writing the report. |
String |
REPORT_KEY_STREAMRESULT
If included in the status or final bundle sent to an IInstrumentationWatcher, this key identifies a string which can simply be printed to the output stream. |
Public constructors | |
---|---|
Instrumentation()
|
Public methods | |
---|---|
TestLooperManager
|
acquireLooperManager(Looper looper)
Takes control of the execution of messages on the specified looper until
|
Instrumentation.ActivityMonitor
|
addMonitor(String cls, Instrumentation.ActivityResult result, boolean block)
A convenience wrapper for |
Instrumentation.ActivityMonitor
|
addMonitor(IntentFilter filter, Instrumentation.ActivityResult result, boolean block)
A convenience wrapper for |
void
|
addMonitor(Instrumentation.ActivityMonitor monitor)
Add a new |
void
|
addResults(Bundle results)
Report some results in the middle of instrumentation execution. |
void
|
callActivityOnCreate(Activity activity, Bundle icicle)
Perform calling of an activity's |
void
|
callActivityOnCreate(Activity activity, Bundle icicle, PersistableBundle persistentState)
Perform calling of an activity's |
void
|
callActivityOnDestroy(Activity activity)
|
void
|
callActivityOnNewIntent(Activity activity, Intent intent, ComponentCaller caller)
Same as |
void
|
callActivityOnNewIntent(Activity activity, Intent intent)
Perform calling of an activity's |
void
|
callActivityOnPause(Activity activity)
Perform calling of an activity's |
void
|
callActivityOnPictureInPictureRequested(Activity activity)
Perform calling of an activity's |
void
|
callActivityOnPostCreate(Activity activity, Bundle savedInstanceState, PersistableBundle persistentState)
Perform calling of an activity's |
void
|
callActivityOnPostCreate(Activity activity, Bundle savedInstanceState)
Perform calling of an activity's |
void
|
callActivityOnRestart(Activity activity)
Perform calling of an activity's |
void
|
callActivityOnRestoreInstanceState(Activity activity, Bundle savedInstanceState)
Perform calling of an activity's |
void
|
callActivityOnRestoreInstanceState(Activity activity, Bundle savedInstanceState, PersistableBundle persistentState)
Perform calling of an activity's |
void
|
callActivityOnResume(Activity activity)
Perform calling of an activity's |
void
|
callActivityOnSaveInstanceState(Activity activity, Bundle outState, PersistableBundle outPersistentState)
Perform calling of an activity's |
void
|
callActivityOnSaveInstanceState(Activity activity, Bundle outState)
Perform calling of an activity's |
void
|
callActivityOnStart(Activity activity)
Perform calling of an activity's |
void
|
callActivityOnStop(Activity activity)
Perform calling of an activity's |
void
|
callActivityOnUserLeaving(Activity activity)
Perform calling of an activity's |
void
|
callApplicationOnCreate(Application app)
Perform calling of the application's |
boolean
|
checkMonitorHit(Instrumentation.ActivityMonitor monitor, int minHits)
Test whether an existing |
void
|
endPerformanceSnapshot()
|
void
|
finish(int resultCode, Bundle results)
Terminate instrumentation of the application. |
Bundle
|
getAllocCounts()
Returns a bundle with the current results from the allocation counting. |
Bundle
|
getBinderCounts()
Returns a bundle with the counts for various binder counts for this process. |
ComponentName
|
getComponentName()
Returns complete component name of this instrumentation. |
Context
|
getContext()
Return the Context of this instrumentation's package. |
String
|
getProcessName()
Return the name of the process this instrumentation is running in. |
Context
|
getTargetContext()
Return a Context for the target application being instrumented. |
UiAutomation
|
getUiAutomation(int flags)
Gets the |
UiAutomation
|
getUiAutomation()
Gets the |
boolean
|
invokeContextMenuAction(Activity targetActivity, int id, int flag)
Show the context menu for the currently focused view and executes a particular context menu item. |
boolean
|
invokeMenuActionSync(Activity targetActivity, int id, int flag)
Execute a particular menu item. |
boolean
|
isProfiling()
Check whether this instrumentation was started with profiling enabled. |
Activity
|
newActivity(Class<?> clazz, Context context, IBinder token, Application application, Intent intent, ActivityInfo info, CharSequence title, Activity parent, String id, Object lastNonConfigurationInstance)
Perform instantiation of an |
Activity
|
newActivity(ClassLoader cl, String className, Intent intent)
Perform instantiation of the process's |
Application
|
newApplication(ClassLoader cl, String className, Context context)
Perform instantiation of the process's |
static
Application
|
newApplication(Class<?> clazz, Context context)
Perform instantiation of the process's |
void
|
onCreate(Bundle arguments)
Called when the instrumentation is starting, before any application code has been loaded. |
void
|
onDestroy()
Called when the instrumented application is stopping, after all of the normal application cleanup has occurred. |
boolean
|
onException(Object obj, Throwable e)
This is called whenever the system captures an unhandled exception that was thrown by the application. |
void
|
onStart()
Method where the instrumentation thread enters execution. |
void
|
removeMonitor(Instrumentation.ActivityMonitor monitor)
Remove an |
void
|
resetInTouchMode()
Resets the |
void
|
runOnMainSync(Runnable runner)
Execute a call on the application's main thread, blocking until it is complete. |
void
|
sendCharacterSync(int keyCode)
Sends up and down key events with the given key code to the currently focused window, and waits for it to be processed. |
void
|
sendKeyDownUpSync(int keyCode)
Sends up and down key events with the given key code to the currently focused window, and waits for it to be processed. |
void
|
sendKeySync(KeyEvent event)
Sends a key event to the currently focused window, and waits for it to be processed. |
void
|
sendPointerSync(MotionEvent event)
Dispatches a pointer event into a window owned by the instrumented application, and waits for it to be processed. |
void
|
sendStatus(int resultCode, Bundle results)
Provide a status report about the application. |
void
|
sendStringSync(String text)
Sends the key events that result in the given text being typed into the currently focused window, and waits for it to be processed. |
void
|
sendTrackballEventSync(MotionEvent event)
Dispatches a trackball event into the currently focused window, and waits for it to be processed. |
void
|
setAutomaticPerformanceSnapshots()
|
void
|
setInTouchMode(boolean inTouch)
Force the global system in or out of touch mode. |
void
|
start()
Create and start a new thread in which to run instrumentation. |
Activity
|
startActivitySync(Intent intent, Bundle options)
Start a new activity and wait for it to begin running before returning. |
Activity
|
startActivitySync(Intent intent)
Start a new activity and wait for it to begin running before returning. |
void
|
startAllocCounting()
|
void
|
startPerformanceSnapshot()
|
void
|
startProfiling()
This method will start profiling if isProfiling() returns true. |
void
|
stopAllocCounting()
|
void
|
stopProfiling()
Stops profiling if isProfiling() returns true. |
void
|
waitForIdle(Runnable recipient)
Schedule a callback for when the application's main thread goes idle (has no more events to process). |
void
|
waitForIdleSync()
Synchronously wait for the application to be idle. |
Activity
|
waitForMonitor(Instrumentation.ActivityMonitor monitor)
Wait for an existing |
Activity
|
waitForMonitorWithTimeout(Instrumentation.ActivityMonitor monitor, long timeOut)
Wait for an existing |
Inherited methods | |
---|---|
Constants
REPORT_KEY_IDENTIFIER
public static final String REPORT_KEY_IDENTIFIER
If included in the status or final bundle sent to an IInstrumentationWatcher, this key identifies the class that is writing the report. This can be used to provide more structured logging or reporting capabilities in the IInstrumentationWatcher.
Constant Value: "id"
REPORT_KEY_STREAMRESULT
public static final String REPORT_KEY_STREAMRESULT
If included in the status or final bundle sent to an IInstrumentationWatcher, this key identifies a string which can simply be printed to the output stream. Using these streams provides a "pretty printer" version of the status & final packets. Any bundles including this key should also include the complete set of raw key/value pairs, so that the instrumentation can also be launched, and results collected, by an automated system.
Constant Value: "stream"
Public constructors
Public methods
acquireLooperManager
public TestLooperManager acquireLooperManager (Looper looper)
Takes control of the execution of messages on the specified looper until
TestLooperManager#release
is called.
Parameters | |
---|---|
looper |
Looper |
Returns | |
---|---|
TestLooperManager |
addMonitor
public Instrumentation.ActivityMonitor addMonitor (String cls, Instrumentation.ActivityResult result, boolean block)
A convenience wrapper for addMonitor(android.app.Instrumentation.ActivityMonitor)
that
creates a class matching ActivityMonitor
for you and returns it.
Parameters | |
---|---|
cls |
String : The activity class this monitor is responsible for. |
result |
Instrumentation.ActivityResult : A canned result to return if the monitor is hit; can
be null. |
block |
boolean : Controls whether the monitor should block the activity
start (returning its canned result) or let the call
proceed. |
Returns | |
---|---|
Instrumentation.ActivityMonitor |
The newly created and added activity monitor. |
addMonitor
public Instrumentation.ActivityMonitor addMonitor (IntentFilter filter, Instrumentation.ActivityResult result, boolean block)
A convenience wrapper for addMonitor(android.app.Instrumentation.ActivityMonitor)
that
creates an intent filter matching ActivityMonitor
for you and
returns it.
Parameters | |
---|---|
filter |
IntentFilter : The set of intents this monitor is responsible for. |
result |
Instrumentation.ActivityResult : A canned result to return if the monitor is hit; can
be null. |
block |
boolean : Controls whether the monitor should block the activity
start (returning its canned result) or let the call
proceed. |
Returns | |
---|---|
Instrumentation.ActivityMonitor |
The newly created and added activity monitor. |
addMonitor
public void addMonitor (Instrumentation.ActivityMonitor monitor)
Add a new ActivityMonitor
that will be checked whenever an
activity is started. The monitor is added
after any existing ones; the monitor will be hit only if none of the
existing monitors can themselves handle the Intent.
Parameters | |
---|---|
monitor |
Instrumentation.ActivityMonitor : The new ActivityMonitor to see. |
addResults
public void addResults (Bundle results)
Report some results in the middle of instrumentation execution. Later results (including
those provided by finish(int, Bundle)
) will be combined with Bundle#putAll
.
Parameters | |
---|---|
results |
Bundle |
callActivityOnCreate
public void callActivityOnCreate (Activity activity, Bundle icicle)
Perform calling of an activity's Activity#onCreate
method. The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being created. |
icicle |
Bundle : The previously frozen state (or null) to pass through to onCreate(). |
callActivityOnCreate
public void callActivityOnCreate (Activity activity, Bundle icicle, PersistableBundle persistentState)
Perform calling of an activity's Activity#onCreate
method. The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being created. |
icicle |
Bundle : The previously frozen state (or null) to pass through to |
persistentState |
PersistableBundle : The previously persisted state (or null) |
callActivityOnDestroy
public void callActivityOnDestroy (Activity activity)
Parameters | |
---|---|
activity |
Activity |
callActivityOnNewIntent
public void callActivityOnNewIntent (Activity activity, Intent intent, ComponentCaller caller)
Same as callActivityOnNewIntent(android.app.Activity, android.content.Intent)
, but with an extra parameter for
the ComponentCaller
instance associated with the app that sent the intent.
Parameters | |
---|---|
activity |
Activity : The activity receiving a new Intent.
This value cannot be null . |
intent |
Intent : The new intent being received.
This value cannot be null . |
caller |
ComponentCaller : The ComponentCaller instance that launched the activity with the new
intent.
This value cannot be null . |
callActivityOnNewIntent
public void callActivityOnNewIntent (Activity activity, Intent intent)
Perform calling of an activity's Activity#onNewIntent
method. The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity receiving a new Intent. |
intent |
Intent : The new intent being received. |
callActivityOnPause
public void callActivityOnPause (Activity activity)
Perform calling of an activity's Activity#onPause
method. The
default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being paused. |
callActivityOnPictureInPictureRequested
public void callActivityOnPictureInPictureRequested (Activity activity)
Perform calling of an activity's Activity#onPictureInPictureRequested
method.
The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being notified that picture-in-picture is being requested.
This value cannot be null . |
callActivityOnPostCreate
public void callActivityOnPostCreate (Activity activity, Bundle savedInstanceState, PersistableBundle persistentState)
Perform calling of an activity's Activity#onPostCreate
method.
The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being created.
This value cannot be null . |
savedInstanceState |
Bundle : The previously frozen state (or null) to pass through to
onPostCreate(). |
persistentState |
PersistableBundle : The previously persisted state (or null) |
callActivityOnPostCreate
public void callActivityOnPostCreate (Activity activity, Bundle savedInstanceState)
Perform calling of an activity's Activity#onPostCreate
method.
The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being created.
This value cannot be null . |
savedInstanceState |
Bundle : The previously saved state (or null) to pass through to
onPostCreate(). |
callActivityOnRestart
public void callActivityOnRestart (Activity activity)
Perform calling of an activity's Activity#onRestart
method. The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being restarted. |
callActivityOnRestoreInstanceState
public void callActivityOnRestoreInstanceState (Activity activity, Bundle savedInstanceState)
Perform calling of an activity's Activity#onRestoreInstanceState
method. The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being restored.
This value cannot be null . |
savedInstanceState |
Bundle : The previously saved state being restored.
This value cannot be null . |
callActivityOnRestoreInstanceState
public void callActivityOnRestoreInstanceState (Activity activity, Bundle savedInstanceState, PersistableBundle persistentState)
Perform calling of an activity's Activity#onRestoreInstanceState
method. The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being restored.
This value cannot be null . |
savedInstanceState |
Bundle : The previously saved state being restored (or null). |
persistentState |
PersistableBundle : The previously persisted state (or null) |
callActivityOnResume
public void callActivityOnResume (Activity activity)
Perform calling of an activity's Activity#onResume
method. The
default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being resumed. |
callActivityOnSaveInstanceState
public void callActivityOnSaveInstanceState (Activity activity, Bundle outState, PersistableBundle outPersistentState)
Perform calling of an activity's Activity#onSaveInstanceState
method. The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being saved.
This value cannot be null . |
outState |
Bundle : The bundle to pass to the call.
This value cannot be null . |
outPersistentState |
PersistableBundle : The persistent bundle to pass to the call.
This value cannot be null . |
callActivityOnSaveInstanceState
public void callActivityOnSaveInstanceState (Activity activity, Bundle outState)
Perform calling of an activity's Activity#onSaveInstanceState
method. The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being saved.
This value cannot be null . |
outState |
Bundle : The bundle to pass to the call.
This value cannot be null . |
callActivityOnStart
public void callActivityOnStart (Activity activity)
Perform calling of an activity's Activity#onStart
method. The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being started. |
callActivityOnStop
public void callActivityOnStop (Activity activity)
Perform calling of an activity's Activity#onStop
method. The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being stopped. |
callActivityOnUserLeaving
public void callActivityOnUserLeaving (Activity activity)
Perform calling of an activity's Activity#onUserLeaveHint
method.
The default implementation simply calls through to that method.
Parameters | |
---|---|
activity |
Activity : The activity being notified that the user has navigated away |
callApplicationOnCreate
public void callApplicationOnCreate (Application app)
Perform calling of the application's Application#onCreate
method. The default implementation simply calls through to that method.
Note: This method will be called immediately after onCreate(android.os.Bundle)
.
Often instrumentation tests start their test thread in onCreate(); you
need to be careful of races between these. (Well between it and
everything else, but let's start here.)
Parameters | |
---|---|
app |
Application : The application being created. |
checkMonitorHit
public boolean checkMonitorHit (Instrumentation.ActivityMonitor monitor, int minHits)
Test whether an existing ActivityMonitor
has been hit. If the
monitor has been hit at least minHits times, then it will be
removed from the activity monitor list and true returned. Otherwise it
is left as-is and false is returned.
Parameters | |
---|---|
monitor |
Instrumentation.ActivityMonitor : The ActivityMonitor to check. |
minHits |
int : The minimum number of hits required. |
Returns | |
---|---|
boolean |
True if the hit count has been reached, else false. |
See also:
finish
public void finish (int resultCode, Bundle results)
Terminate instrumentation of the application. This will cause the application process to exit, removing this instrumentation from the next time the application is started. If multiple processes are currently running for this instrumentation, all of those processes will be killed.
Parameters | |
---|---|
resultCode |
int : Overall success/failure of instrumentation. |
results |
Bundle : Any results to send back to the code that started the
instrumentation. |
getAllocCounts
public Bundle getAllocCounts ()
Returns a bundle with the current results from the allocation counting.
Returns | |
---|---|
Bundle |
getBinderCounts
public Bundle getBinderCounts ()
Returns a bundle with the counts for various binder counts for this process. Currently the only two that are reported are the number of send and the number of received transactions.
Returns | |
---|---|
Bundle |
getComponentName
public ComponentName getComponentName ()
Returns complete component name of this instrumentation.
Returns | |
---|---|
ComponentName |
Returns the complete component name for this instrumentation. |
getContext
public Context getContext ()
Return the Context of this instrumentation's package. Note that this is
often different than the Context of the application being
instrumentated, since the instrumentation code often lives is a
different package than that of the application it is running against.
See getTargetContext()
to retrieve a Context for the target
application.
Returns | |
---|---|
Context |
The instrumentation's package context. |
See also:
getProcessName
public String getProcessName ()
Return the name of the process this instrumentation is running in. Note this should only be used for testing and debugging. If you are thinking about using this to, for example, conditionalize what is initialized in an Application class, it is strongly recommended to instead use lazy initialization (such as a getter for the state that only creates it when requested). This can greatly reduce the work your process does when created for secondary things, such as to receive a broadcast.
Returns | |
---|---|
String |
getTargetContext
public Context getTargetContext ()
Return a Context for the target application being instrumented. Note
that this is often different than the Context of the instrumentation
code, since the instrumentation code often lives is a different package
than that of the application it is running against. See
getContext()
to retrieve a Context for the instrumentation code.
Returns | |
---|---|
Context |
A Context in the target application. |
See also:
getUiAutomation
public UiAutomation getUiAutomation (int flags)
Gets the UiAutomation
instance with flags set.
Note: The APIs exposed via the returned UiAutomation
work across application boundaries while the APIs exposed by the instrumentation
do not. For example, Instrumentation#sendPointerSync(MotionEvent)
will
not allow you to inject the event in an app different from the instrumentation
target, while UiAutomation#injectInputEvent(android.view.InputEvent, boolean)
will work regardless of the current application.
A typical test case should be using either the UiAutomation
or
Instrumentation
APIs. Using both APIs at the same time is not
a mistake by itself but a client has to be aware of the APIs limitations.
If a UiAutomation
exists with different flags, the flags on that instance will be
changed, and then it will be returned.
Compatibility mode: This method is infallible for apps targeted for
Build.VERSION_CODES#R
and earlier versions; for apps targeted for later versions, it
will return null if UiAutomation
fails to connect. The caller can check the return
value and retry on error.
Parameters | |
---|---|
flags |
int : The flags to be passed to the UiAutomation, for example
UiAutomation#FLAG_DONT_SUPPRESS_ACCESSIBILITY_SERVICES ,
UiAutomation#FLAG_DONT_USE_ACCESSIBILITY .
Value is 0, UiAutomation.FLAG_DONT_SUPPRESS_ACCESSIBILITY_SERVICES , or UiAutomation.FLAG_DONT_USE_ACCESSIBILITY |
Returns | |
---|---|
UiAutomation |
The UI automation instance. |
See also:
getUiAutomation
public UiAutomation getUiAutomation ()
Gets the UiAutomation
instance with no flags set.
Note: The APIs exposed via the returned UiAutomation
work across application boundaries while the APIs exposed by the instrumentation
do not. For example, Instrumentation#sendPointerSync(MotionEvent)
will
not allow you to inject the event in an app different from the instrumentation
target, while UiAutomation#injectInputEvent(android.view.InputEvent, boolean)
will work regardless of the current application.
A typical test case should be using either the UiAutomation
or
Instrumentation
APIs. Using both APIs at the same time is not
a mistake by itself but a client has to be aware of the APIs limitations.
Equivalent to getUiAutomation(0)
. If a UiAutomation
exists with different
flags, the flags on that instance will be changed, and then it will be returned.
Compatibility mode: This method is infallible for apps targeted for
Build.VERSION_CODES#R
and earlier versions; for apps targeted for later versions, it
will return null if UiAutomation
fails to connect. The caller can check the return
value and retry on error.
Returns | |
---|---|
UiAutomation |
The UI automation instance. |
See also:
invokeContextMenuAction
public boolean invokeContextMenuAction (Activity targetActivity, int id, int flag)
Show the context menu for the currently focused view and executes a particular context menu item.
Parameters | |
---|---|
targetActivity |
Activity : The activity in question. |
id |
int : The identifier associated with the context menu item. |
flag |
int : Additional flags, if any. |
Returns | |
---|---|
boolean |
Whether the invocation was successful (for example, it could be false if item is disabled). |
invokeMenuActionSync
public boolean invokeMenuActionSync (Activity targetActivity, int id, int flag)
Execute a particular menu item.
Parameters | |
---|---|
targetActivity |
Activity : The activity in question. |
id |
int : The identifier associated with the menu item. |
flag |
int : Additional flags, if any. |
Returns | |
---|---|
boolean |
Whether the invocation was successful (for example, it could be false if item is disabled). |
isProfiling
public boolean isProfiling ()
Check whether this instrumentation was started with profiling enabled.
Returns | |
---|---|
boolean |
Returns true if profiling was enabled when starting, else false. |
newActivity
public Activity newActivity (Class<?> clazz, Context context, IBinder token, Application application, Intent intent, ActivityInfo info, CharSequence title, Activity parent, String id, Object lastNonConfigurationInstance)
Perform instantiation of an Activity
object. This method is intended for use with
unit tests, such as android.test.ActivityUnitTestCase. The activity will be useable
locally but will be missing some of the linkages necessary for use within the system.
Parameters | |
---|---|
clazz |
Class : The Class of the desired Activity |
context |
Context : The base context for the activity to use |
token |
IBinder : The token for this activity to communicate with |
application |
Application : The application object (if any) |
intent |
Intent : The intent that started this Activity |
info |
ActivityInfo : ActivityInfo from the manifest |
title |
CharSequence : The title, typically retrieved from the ActivityInfo record |
parent |
Activity : The parent Activity (if any) |
id |
String : The embedded Id (if any) |
lastNonConfigurationInstance |
Object : Arbitrary object that will be
available via Activity.getLastNonConfigurationInstance() . |
Returns | |
---|---|
Activity |
Returns the instantiated activity |
Throws | |
---|---|
|
java.lang.InstantiationException |
|
java.lang.IllegalAccessException |
IllegalAccessException |
|
InstantiationException |
newActivity
public Activity newActivity (ClassLoader cl, String className, Intent intent)
Perform instantiation of the process's Activity
object. The
default implementation provides the normal system behavior.
Parameters | |
---|---|
cl |
ClassLoader : The ClassLoader with which to instantiate the object. |
className |
String : The name of the class implementing the Activity
object. |
intent |
Intent : The Intent object that specified the activity class being
instantiated. |
Returns | |
---|---|
Activity |
The newly instantiated Activity object. |
Throws | |
---|---|
ClassNotFoundException |
|
IllegalAccessException |
|
InstantiationException |
newApplication
public Application newApplication (ClassLoader cl, String className, Context context)
Perform instantiation of the process's Application
object. The
default implementation provides the normal system behavior.
Parameters | |
---|---|
cl |
ClassLoader : The ClassLoader with which to instantiate the object. |
className |
String : The name of the class implementing the Application
object. |
context |
Context : The context to initialize the application with |
Returns | |
---|---|
Application |
The newly instantiated Application object. |
Throws | |
---|---|
ClassNotFoundException |
|
IllegalAccessException |
|
InstantiationException |
newApplication
public static Application newApplication (Class<?> clazz, Context context)
Perform instantiation of the process's Application
object. The
default implementation provides the normal system behavior.
Parameters | |
---|---|
clazz |
Class : The class used to create an Application object from. |
context |
Context : The context to initialize the application with |
Returns | |
---|---|
Application |
The newly instantiated Application object. |
Throws | |
---|---|
ClassNotFoundException |
|
IllegalAccessException |
|
InstantiationException |
onCreate
public void onCreate (Bundle arguments)
Called when the instrumentation is starting, before any application code
has been loaded. Usually this will be implemented to simply call
start()
to begin the instrumentation thread, which will then
continue execution in onStart()
.
If you do not need your own thread -- that is you are writing your
instrumentation to be completely asynchronous (returning to the event
loop so that the application can run), you can simply begin your
instrumentation here, for example call Context#startActivity
to
begin the appropriate first activity of the application.
Parameters | |
---|---|
arguments |
Bundle : Any additional arguments that were supplied when the
instrumentation was started. |
onDestroy
public void onDestroy ()
Called when the instrumented application is stopping, after all of the normal application cleanup has occurred.
onException
public boolean onException (Object obj, Throwable e)
This is called whenever the system captures an unhandled exception that was thrown by the application. The default implementation simply returns false, allowing normal system handling of the exception to take place.
Parameters | |
---|---|
obj |
Object : The client object that generated the exception. May be an
Application, Activity, BroadcastReceiver, Service, or null. |
e |
Throwable : The exception that was thrown. |
Returns | |
---|---|
boolean |
To allow normal system exception process to occur, return false. If true is returned, the system will proceed as if the exception didn't happen. |
onStart
public void onStart ()
Method where the instrumentation thread enters execution. This allows
you to run your instrumentation code in a separate thread than the
application, so that it can perform blocking operation such as
sendKeySync(KeyEvent)
or startActivitySync(Intent)
.
You will typically want to call finish() when this function is done, to end your instrumentation.
removeMonitor
public void removeMonitor (Instrumentation.ActivityMonitor monitor)
Remove an ActivityMonitor
that was previously added with
addMonitor(ActivityMonitor)
.
Parameters | |
---|---|
monitor |
Instrumentation.ActivityMonitor : The monitor to remove. |
See also:
resetInTouchMode
public void resetInTouchMode ()
Resets the touch mode
to the device default.
runOnMainSync
public void runOnMainSync (Runnable runner)
Execute a call on the application's main thread, blocking until it is complete. Useful for doing things that are not thread-safe, such as looking at or modifying the view hierarchy.
Parameters | |
---|---|
runner |
Runnable : The code to run on the main thread. |
sendCharacterSync
public void sendCharacterSync (int keyCode)
Sends up and down key events with the given key code to the currently focused window, and waits for it to be processed.
Equivalent to sendKeyDownUpSync(int)
.
Parameters | |
---|---|
keyCode |
int : The key code of the character to send. |
See also:
sendKeyDownUpSync
public void sendKeyDownUpSync (int keyCode)
Sends up and down key events with the given key code to the currently focused window, and waits for it to be processed.
Parameters | |
---|---|
keyCode |
int : The key code for the events to send. |
See also:
sendKeySync
public void sendKeySync (KeyEvent event)
Sends a key event to the currently focused window, and waits for it to be processed.
This method blocks until the recipient has finished handling the event. Note that the recipient may not have completely finished reacting from the event when this method returns. For example, it may still be in the process of updating its display or UI contents upon reacting to the injected event.
Parameters | |
---|---|
event |
KeyEvent : The event to send to the current focus. |
sendPointerSync
public void sendPointerSync (MotionEvent event)
Dispatches a pointer event into a window owned by the instrumented application, and waits for it to be processed.
If the motion event being injected is targeted at a window that is not owned by the
instrumented application, the input injection will fail. See getUiAutomation()
for
injecting events into all windows.
This method blocks until the recipient has finished handling the event. Note that the recipient may not have completely finished reacting from the event when this method returns. For example, it may still be in the process of updating its display or UI contents upon reacting to the injected event.
Parameters | |
---|---|
event |
MotionEvent : A motion event describing the pointer action. (As noted in
MotionEvent#obtain(long, long, int, float, float, int) , be sure to use
SystemClock#uptimeMillis() as the timebase. |
sendStatus
public void sendStatus (int resultCode, Bundle results)
Provide a status report about the application.
Parameters | |
---|---|
resultCode |
int : Current success/failure of instrumentation. |
results |
Bundle : Any results to send back to the code that started the instrumentation. |
sendStringSync
public void sendStringSync (String text)
Sends the key events that result in the given text being typed into the currently focused window, and waits for it to be processed.
Parameters | |
---|---|
text |
String : The text to be sent. |
See also:
sendTrackballEventSync
public void sendTrackballEventSync (MotionEvent event)
Dispatches a trackball event into the currently focused window, and waits for it to be processed.
This method blocks until the recipient has finished handling the event. Note that the recipient may not have completely finished reacting from the event when this method returns. For example, it may still be in the process of updating its display or UI contents upon reacting to the injected event.
Parameters | |
---|---|
event |
MotionEvent : A motion event describing the trackball action. (As noted in
MotionEvent#obtain(long, long, int, float, float, int) , be sure to use
SystemClock#uptimeMillis() as the timebase. |
setAutomaticPerformanceSnapshots
public void setAutomaticPerformanceSnapshots ()
setInTouchMode
public void setInTouchMode (boolean inTouch)
Force the global system in or out of touch mode. This can be used if your instrumentation relies on the UI being in one more or the other when it starts.
Note: Starting from Android Build.VERSION_CODES#TIRAMISU
, this method
will only take effect if the instrumentation was sourced from a process with
MODIFY_TOUCH_MODE_STATE
internal permission granted (shell already have it).
Parameters | |
---|---|
inTouch |
boolean : Set to true to be in touch mode, false to be in focus mode. |
start
public void start ()
Create and start a new thread in which to run instrumentation. This new
thread will call to onStart()
where you can implement the
instrumentation.
startActivitySync
public Activity startActivitySync (Intent intent, Bundle options)
Start a new activity and wait for it to begin running before returning.
In addition to being synchronous, this method as some semantic
differences from the standard Context#startActivity
call: the
activity component is resolved before talking with the activity manager
(its class name is specified in the Intent that this method ultimately
starts), and it does not allow you to start activities that run in a
different process. In addition, if the given Intent resolves to
multiple activities, instead of displaying a dialog for the user to
select an activity, an exception will be thrown.
The function returns as soon as the activity goes idle following the
call to its Activity#onCreate
. Generally this means it has gone
through the full initialization including Activity#onResume
and
drawn and displayed its initial window.
Parameters | |
---|---|
intent |
Intent : Description of the activity to start.
This value cannot be null . |
options |
Bundle : Additional options for how the Activity should be started.
May be null if there are no options. See ActivityOptions
for how to build the Bundle supplied here; there are no supported definitions
for building it manually. |
Returns | |
---|---|
Activity |
This value cannot be null . |
See also:
startActivitySync
public Activity startActivitySync (Intent intent)
Start a new activity and wait for it to begin running before returning.
In addition to being synchronous, this method as some semantic
differences from the standard Context#startActivity
call: the
activity component is resolved before talking with the activity manager
(its class name is specified in the Intent that this method ultimately
starts), and it does not allow you to start activities that run in a
different process. In addition, if the given Intent resolves to
multiple activities, instead of displaying a dialog for the user to
select an activity, an exception will be thrown.
The function returns as soon as the activity goes idle following the
call to its Activity#onCreate
. Generally this means it has gone
through the full initialization including Activity#onResume
and
drawn and displayed its initial window.
Parameters | |
---|---|
intent |
Intent : Description of the activity to start. |
Returns | |
---|---|
Activity |
startAllocCounting
public void startAllocCounting ()
startProfiling
public void startProfiling ()
This method will start profiling if isProfiling() returns true. You should only call this method if you set the handleProfiling attribute in the manifest file for this Instrumentation to true.
stopProfiling
public void stopProfiling ()
Stops profiling if isProfiling() returns true.
waitForIdle
public void waitForIdle (Runnable recipient)
Schedule a callback for when the application's main thread goes idle (has no more events to process).
Parameters | |
---|---|
recipient |
Runnable : Called the next time the thread's message queue is
idle. |
waitForIdleSync
public void waitForIdleSync ()
Synchronously wait for the application to be idle. Can not be called
from the main application thread -- use start()
to execute
instrumentation in its own thread.
waitForMonitor
public Activity waitForMonitor (Instrumentation.ActivityMonitor monitor)
Wait for an existing ActivityMonitor
to be hit. Once the
monitor has been hit, it is removed from the activity monitor list and
the first created Activity object that matched it is returned.
Parameters | |
---|---|
monitor |
Instrumentation.ActivityMonitor : The ActivityMonitor to wait for. |
Returns | |
---|---|
Activity |
The Activity object that matched the monitor. |
waitForMonitorWithTimeout
public Activity waitForMonitorWithTimeout (Instrumentation.ActivityMonitor monitor, long timeOut)
Wait for an existing ActivityMonitor
to be hit till the timeout
expires. Once the monitor has been hit, it is removed from the activity
monitor list and the first created Activity object that matched it is
returned. If the timeout expires, a null object is returned.
Parameters | |
---|---|
monitor |
Instrumentation.ActivityMonitor : The ActivityMonitor to wait for. |
timeOut |
long : The timeout value in milliseconds. |
Returns | |
---|---|
Activity |
The Activity object that matched the monitor. |
Content and code samples on this page are subject to the licenses described in the Content License. Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
Last updated 2024-06-18 UTC.