platform_system_core/init/test_service
Jorge Lucangeli Obes 28e980b59c Add a sample service for testing init.
I find myself using something like this every time I add functionality
to init. I cannot possibly be the only one doing this. On the other
hand, if this hasn't been added for so long, maybe there's a reason
for that.

The advantage of using a test service versus modifying an existing
service is that the test service doesn't *require* any permissions or
privileges, so you can add and/or remove whatever you need to test
without breaking the service.

I found it useful to have the service check its own /proc/<pid>/status
from command-line arguments, so that's what the service does.

This CL also adds a .clang-format file for init.

Bug: None
Test: Service runs and exits successfully.

Change-Id: I3e7841a7283158e10c0bf55e0103c03902afb1f0
2017-02-09 18:23:09 -05:00
..
Android.mk Add a sample service for testing init. 2017-02-09 18:23:09 -05:00
README.md Add a sample service for testing init. 2017-02-09 18:23:09 -05:00
test_service.cpp Add a sample service for testing init. 2017-02-09 18:23:09 -05:00
test_service.rc Add a sample service for testing init. 2017-02-09 18:23:09 -05:00

README.md

Sample service for testing

This is a sample service that can be used for testing init.

Design

The service includes a .rc file that allows starting it from init.

service test_service /system/bin/test_service CapAmb 0000000000003000
    class main
    user system
    group system
    capabilities NET_ADMIN NET_RAW
    disabled
    oneshot

The service accepts any even number of arguments on the command line (i.e. any number of pairs of arguments.) It will attempt to find the first element of each pair of arguments in /proc/self/status, and attempt to exactly match the second element of the pair to the relevant line of proc/self/status.

Example

In the above case, the service will look for lines containing CapAmb:

cat /proc/self/status
...
CapAmb:	0000000000003000

And then attempt to exactly match the token after :, 0000000000003000, with the command-line argument. If they match, the service exits successfully. If not, the service will exit with an error.

Usage

mmma -j <jobs> system/core/init/testservice
adb root
adb remount
adb sync
adb reboot
adb root
adb shell start test_service
adb logcat -b all -d | grep test_service

Look for an exit status of 0.