History log of /frameworks/base/tools/bit/main.cpp
Revision Date Author Comments (<<< Hide modified files) (Show modified files >>>)
2cfa849e9289474d82773335e6f54d751103a53a 07-Dec-2016 Yunlian Jiang <yunlian@google.com> fix warning: Potential leak of memory pointed to by 'target'

Bug: None
Test: The warning is gone.
Change-Id: I013fad1d53b37ae3d89846c70f0b10a67a9d04bb
/frameworks/base/tools/bit/main.cpp
6592c3cc8f37aae2058021b7971c33b94fc7ce5d 13-Nov-2016 Joe Onorato <joeo@google.com> Add an option to bit to not restart.

Test: build & restart
Change-Id: Ia925053f04046d7fb91a47cfd5fd17a5d4fecf10
/frameworks/base/tools/bit/main.cpp
8a5bb6370cd01990d2bb9f74dc4c777d68e95adc 21-Oct-2016 Joe Onorato <joeo@google.com> Fix mac build of bit

Test: make bit
Change-Id: I8005e77babfbe2d48806f9315800e699d1917bb4
/frameworks/base/tools/bit/main.cpp
0578cbc6c527bc09a38a0fcd8b9642c25c8ea023 20-Oct-2016 Joe Onorato <joeo@google.com> Add a new build, install, test development (bit) tool

This is a cleaned up version of a utility that I've had sitting around
for a while.

The bit tool can run an android platform build, then sync or install
the outputs of that, and then run instrumentation tests. It's better
than what we usually do:

make && adb shell stop && adb sync system && adb shell start

Here's the help text:

usage: bit OPTIONS PATTERN

Build, sync and test android code.

The -b -i and -t options allow you to specify which phases
you want to run. If none of those options are given, then
all phases are run. If any of these options are provided
then only the listed phases are run.

OPTIONS
-b Run a build
-i Install the targets
-t Run the tests

PATTERN
One or more targets to build, install and test. The target
names are the names that appear in the LOCAL_MODULE or
LOCAL_PACKAGE_NAME variables in Android.mk or Android.bp files.

Building and installing
-----------------------
The modules specified will be built and then installed. If the
files are on the system partition, they will be synced and the
attached device rebooted. If they are APKs that aren't on the
system partition they are installed with adb install.

For example:
bit framework
Builds framework.jar, syncs the system partition and reboots.

bit SystemUI
Builds SystemUI.apk, syncs the system partition and reboots.

bit CtsProtoTestCases
Builds this CTS apk, adb installs it, but does not run any
tests.

Running Unit Tests
------------------
To run a unit test, list the test class names and optionally the
test method after the module.

For example:
bit CtsProtoTestCases:*
Builds this CTS apk, adb installs it, and runs all the tests
contained in that apk.

bit framework CtsProtoTestCases:*
Builds the framework and the apk, syncs and reboots, then
adb installs CtsProtoTestCases.apk, and runs all tests
contained in that apk.

bit CtsProtoTestCases:.ProtoOutputStreamBoolTest
bit CtsProtoTestCases:android.util.proto.cts.ProtoOutputStreamBoolTest
Builds and installs CtsProtoTestCases.apk, and runs all the
tests in the ProtoOutputStreamBoolTest class.

bit CtsProtoTestCases:.ProtoOutputStreamBoolTest\#testWrite
Builds and installs CtsProtoTestCases.apk, and runs the testWrite
test method on that class.

bit CtsProtoTestCases:.ProtoOutputStreamBoolTest\#testWrite,.ProtoOutputStreamBoolTest\#testRepeated
Builds and installs CtsProtoTestCases.apk, and runs the testWrite
and testRepeated test methods on that class.

Launching an Activity
---------------------
To launch an activity, specify the activity class name after
the module name.

For example:
bit StatusBarTest:NotificationBuilderTest
bit StatusBarTest:.NotificationBuilderTest
bit StatusBarTest:com.android.statusbartest.NotificationBuilderTest
Builds and installs StatusBarTest.apk, launches the
com.android.statusbartest/.NotificationBuilderTest activity.

Change-Id: I9cff7a23852fa1a67369e7807f7ae9f6e45d6131
Test: none
/frameworks/base/tools/bit/main.cpp