Home | History | Annotate | Download | only in dumpstate
      1 # `dumpstate` development tips
      2 
      3 ## To build `dumpstate`
      4 
      5 Do a full build first:
      6 
      7 ```
      8 m -j dumpstate
      9 ```
     10 
     11 Then incremental ones:
     12 
     13 ```
     14 mmm -j frameworks/native/cmds/dumpstate
     15 ```
     16 
     17 If you're working on device-specific code, you might need to build them as well.
     18 Example:
     19 
     20 ```
     21 mmm -j frameworks/native/cmds/dumpstate device/acme/secret_device/dumpstate/ hardware/interfaces/dumpstate
     22 ```
     23 
     24 ## To build, deploy, and take a bugreport
     25 
     26 ```
     27 mmm -j frameworks/native/cmds/dumpstate && adb push ${OUT}/system/bin/dumpstate system/bin && adb push ${OUT}/system/lib64/*dumpstate*.so /system/lib64/ && adb shell am bug-report
     28 ```
     29 
     30 Make sure that the device is remounted before running the above command. * If
     31 you're working with `userdebug` variant, you may need to run the following to
     32 remount your device:
     33 
     34 ```
     35   adb root && adb remount -R && adb wait-for-device && adb root && adb remount
     36 ```
     37 
     38 *   If you're working with `eng` variant, you may need to run the following to
     39     remount your device:
     40 
     41     ```
     42     adb root && adb remount
     43     ```
     44 
     45 ## To build, deploy, and run unit tests
     46 
     47 First create `/data/nativetest64`:
     48 
     49 ```
     50 adb shell mkdir /data/nativetest64
     51 ```
     52 
     53 Then run:
     54 
     55 ```
     56 mmm -j frameworks/native/cmds/dumpstate/ && adb push ${OUT}/data/nativetest64/dumpstate_* /data/nativetest64 && adb shell /data/nativetest64/dumpstate_test/dumpstate_test
     57 ```
     58 
     59 And to run just one test (for example, `DumpstateTest.RunCommandNoArgs`):
     60 
     61 ```
     62 mmm -j frameworks/native/cmds/dumpstate/ && adb push ${OUT}/data/nativetest64/dumpstate_test* /data/nativetest64 && adb shell /data/nativetest64/dumpstate_test/dumpstate_test --gtest_filter=DumpstateTest.RunCommandNoArgs
     63 ```
     64 
     65 ## To take quick bugreports
     66 
     67 ```
     68 adb shell setprop dumpstate.dry_run true
     69 ```
     70 
     71 ## To emulate a device with user build
     72 
     73 ```
     74 adb shell setprop dumpstate.unroot true
     75 ```
     76 
     77 ## To change the `dumpstate` version
     78 
     79 ```
     80 adb shell setprop dumpstate.version VERSION_NAME
     81 ```
     82 
     83 Example:
     84 
     85 ```
     86 adb shell setprop dumpstate.version split-dumpsys && adb shell dumpstate -v
     87 ```
     88 
     89 Then to restore the default version:
     90 
     91 ```
     92 adb shell setprop dumpstate.version default
     93 ```
     94 
     95 ## Code style and formatting
     96 
     97 Use the style defined at the
     98 [Google C++ Style Guide](https://google.github.io/styleguide/cppguide.html) and
     99 make sure to run the following command prior to `repo upload`:
    100 
    101 ```
    102 git clang-format --style=file HEAD~
    103 ```
    104 
    105 ## Useful Bash tricks
    106 
    107 ```
    108 export BR_DIR=/bugreports
    109 
    110 alias br='adb shell cmd activity bug-report'
    111 alias ls_bugs='adb shell ls -l ${BR_DIR}/'
    112 
    113 unzip_bug() {
    114   adb pull ${BR_DIR}/$1 && emacs $1 && mv $1 /tmp
    115 }
    116 
    117 less_bug() {
    118   adb pull ${BR_DIR}/$1 && less $1 && mv $1 /tmp
    119 }
    120 
    121 rm_bugs() {
    122  if [ -z "${BR_DIR}" ] ; then echo "Variable BR_DIR not set"; else adb shell rm -rf ${BR_DIR}/*; fi
    123 }
    124 
    125 ```
    126