The table below lists all of the supported adb commands and explains their meaning and usage.
Category | Command | Description | |
---|---|---|---|
Options | -d | Direct an adb command to the only attached USB device. | |
-e | Direct an adb command to the only running emulator instance. | ||
-s <serialNumber> | Direct an adb command a specific emulator/device instance, referred to by its adb-assigned serial number (such as "emulator-5556"). | ||
General | devices | Prints a list of all attached emulator/device instances. | |
help | Prints a list of supported adb commands. | ||
version | Prints the adb version number. | ||
Debug | logcat [<option>] [<filter-specs>] | Prints log data to the screen. | |
bugreport | Prints dumpsys , dumpstate , andlogcat data to the screen, for the purposes of bug reporting. | ||
jdwp | Prints a list of available JDWP processes on a given device. | ||
Data |
install <path- to-apk> | Pushes an Android You can use the forward jdwp:<pid> port-forwarding specification to connect to a specific JDWP process. For example:adb forward tcp:8000 jdwp:472 jdb -attach localhost:8000 application(specified as a full path to an .apk file) to the data file of an emulator/device. | |
pull <remote> <local> | Copies a specified file from an emulator/device instance to your development computer. | ||
push <local> <remote> | Copies a specified file from your development computer to an emulator/device instance. | ||
Ports and Networking | forward <local> <remote> | Forwards socket connections from a specified local port to a specified remote port on the emulator/device instance. | |
ppp <tty> [parm]... | Run PPP over USB.
Note that you should not automatically start a PDP connection.
| ||
Scripting | get-serialno | Prints the adb instance serial number string. | |
get-state | Prints the adb state of an emulator/device instance. | ||
wait-for-device | Blocks execution until the device is online — that is, until the instance state is device . |
| |
Server | start-server | Checks whether the adb server process is running and starts it, if not. | |
kill-server | Terminates the adb serverprocess. | ||
Shell | shell | Starts a remote shell in the target emulator/device instance. | |
shell [<shellCommand>] | Issues a shell command in the target emulator/device instance and then exits the remote shell. |
Step 1: Using the ADB Command
The ADB tool is launched from the command line.
At your command prompt, simply type:
1
| adb |
This runs ADB and shows a list of a bunch of commands.
If you do not see the list of commands, go back and check your installation and environment path settings, as described in previous tutorials. It could be that you have the ADB program installed, but if you don't have your shell's PATH environment variable configured correctly, you would need to type the full file path to ADB at the terminal to launch the program. Done? Good.
So back to that list of commands. The ADB tool serves two purposes. The first is to allow many of the other Android tools to interact with devices and emulators. The second is to allow you, the developer, to talk to devices and emulators by issuing different commands manually.
ADB commands come in two forms. One form of command you run directly from ADB. Another form of command, which isn't directly ADB but is commonly done through ADB, is done through the "adb shell" command.
Now, before going on, have an emulator instance running or an Android device connected to your development machine. Now, if you use the ADB devices command, it should list any attached devices or emulator instances:
1
| adb devices |
You should see something like this:
If not, make sure your emulator is running or restart the ADB server.
Step 2: Restarting the ADB Server
To restart the ADB server, here's another command for you:
1
2
| adb stop-server adb start-server |
Once you're ready to, continue on. We'll be covering many commands, in no particular order.
Part 1: Regular Commands
Here are a variety of commands run directly via ADB. This will be followed by several commands that first require opening a shell.
Push and Pull
You can copy files to and from a connected device using the ADB push and ADB pull commands.
1
2
| adb push < local source file path> <device destination file path> adb pull <device source file path> < local destination file path> |
These commands are very useful for things like refreshing preference XML files for your app during testing, and other such things.
App Installation and Removal
You can use ADB to install or remove apps (apks) from your devices. Use the install command to install an Android package file/
1
| adb install < file path to apk> |
Likewise, you can remove an existing app by its package name.
1
| adb uninstall <package name> |
You may find yourself needing to uninstall apps if you're moving between development machines that don't share the same app signing key. It's also a fast way to clean up, or load up, a device without having to use Eclipse and the ADT plug-in.
Backup and Restore
You can backup and restore the contents of a device. This has limitations on devices that aren't rooted.
1
2
| adb backup adb restore <archive name> |
See 'adb help' for all the options of backup and restore. This could be useful for storing off app data during testing and then restoring this data easily for repeat testing.
Device Rebooting
You can reboot a device either normally, into the bootloader, or into recovery mode.
1
2
3
| adb reboot adb reboot recovery adb reboot bootloader |
In our experience, these aren't appropriate for the emulator. However, there are times with Android devices get confused and need a hard reboot.
Shell Command
The ADB tool has a shell interface. To issue shell commands, you must first launch this interface by typing adb shell:
1
| adb shell |
Once run, you'll be in a bash environment. You can run bash commands, like df to show free disk space, uptime to see how long the device has been running or exit to exit the shell interface:
If you're not familiar with Linux, you may have a harder time getting around in the shell. There are numerous guides online that will provide you with help for bash commands such as ls, cp, cd, and so on.
Part 2: Shell Commands
Here are several special commands you can run when in the shell. Not all ADB shell commands work on physical devices or emulators.
Logcat
You can use the logcat command to view logging output much as you do in Eclipse:
1
2
3
| adb shell logcat --help logcat -t 5 |
There are many options available with the logcat tool. By default, the output comes in real time, much like it does when viewed with Eclipse. One feature that's nice is you can send the output to a file using the -f option.
Backup Manager
The bmgr tool is the backup manager. You can use this tool to trigger app-level data backup and restore operations. Your app must support backups for this to be useful.
Monkey Stress Tester
You can use the monkey tool to test your apps. This simulates a variety of different user input events, much like a monkey or toddler banging on a keyboard. Use this for stress testing.
The monkey tool can be scripted, as well, and supports repeatable streams of events through the -s switch, so tests can be reviewed and repeated.
SQLite 3
You can run sqlite commands and interact with application databases using the adb shell as well. You'll need read/write access to the databases you're interested in inspecting or altering (in other words, your own apps, not others).
Thank you for your post. This is excellent information. It is amazing and wonderful to visit your blog.
ReplyDeleteBest ios training institute in bangalore
iOS app training in bangalore