田海立
2012/10/9
本文简析Android内置的Factory Test(有测试模式/工厂模式/工程模式等叫法)框架,并非讲解FactoryTest中的每个测试该怎么写。
Android框架中已经对FactoryTest做了支持,通过一些配置和开发工作就可以把FactoryTest代码融入到Android系统中。
Android系统中在com.android.server.SystemServer(loc:frameworks/base/services/java/)中对FactoryTest的级别做了定义:
public static final int FACTORY_TEST_OFF =0; public static final int FACTORY_TEST_LOW_LEVEL = 1; public static final int FACTORY_TEST_HIGH_LEVEL= 2;
后面着重来看FACTORY_TEST_LOW_LEVEL,也用此模式来代替FactoryTest的表述。
系统从FACTORY_TEST_LOW_LEVEL模式启动,下列服务或Observer根本就不会被启动:
BluetoothService
BluetoothA2dpService
DevicePolicyService
StatusBarManagerService
ClipboardService
InputMethodManagerService
NetStatService
NetworkManagementService
ConnectivityService
ThrottleService
AccessibilityManagerService
MountService
NotificationManagerService
DeviceStorageMonitorService
LocationManagerService
SearchManagerService
DropBoxManagerService
WallpaperManagerService
AudioService
HeadsetObserver
HookSwitchObserver
HdmiObserver
DockObserver
UsbService
UiModeManagerService
BackupManagerService
AppWidgetService
RecognitionManagerService
DiskStatsService
而下列基本的服务会在FACTORY_TEST_LOW_LEVEL模式时执行的路径有所不同:
ActivityManagerService
FACTORY_TEST_LOW_LEVEL模式时,不会发出BOOT_COMPLETED广播;启动第一个程序不是通过Acrtion为MAIN,Category为Home的Intent来启动第一个程序,而是通过Acrtion为Intent.ACTION_FACTORY_TEST (“android.intent.action.FACTORY_TEST)的Intent来启动。
PackageManagerService
FACTORY_TEST_LOW_LEVEL模式时,对包含FACTORY_TEST这个Permission的包,加上ApplicationInfo.FLAG_FACTORY_TEST的标志。
ContentService
FACTORY_TEST_LOW_LEVEL模式时,SyncManager会因为FactoryTest模式下的差异,而表现不同。
WindowManagerService
FACTORY_TEST_LOW_LEVEL模式时,没有输入法。
由上面简要分析知道,FACTORY_TEST_LOW_LEVEL模式下,要对FactoryTest程序进行配置。另外,如何进入FactoryTest模式也要进行配置。
由上面简要分析知道,FACTORY_TEST_LOW_LEVEL模式下,第一个被启动的程序就是工程模式的测试程序,而这个程序必须:
响应Action为Intent.ACTION_FACTORY_TEST (“android.intent.action.FACTORY_TEST”)的Activity在开机之后就被执行。
启动模式是由“ro.factorytest”这个系统属性来决定的,取值范围是0/1/2,对应第一部分定义的三个级别模式。可在在.mk文件中通过PRODUCT_PROPERTY_OVERRIDES或ADDITIONAL_DEFUALT_PROPERTIES追加一个这样的属性。比如:
#FactoryTest LowLevel PRODUCT_PROPERTY_OVERRIDE += ro.factorytest=1
有些实现通过上面的设置还不起作用,那是因为在内核启动时,通过启动模式对“ro.factorytest”这个系统属性进行了设置。
理想状态是由内核来决定启动模式,而不需要上小节的设置。
内核通过参数“androidboot.mode”来决定工厂模式(”factory”对应FACTORY_TEST_LOW_LEVEL;”factory2”对应FACTORY_TEST_HIGH_LEVEL;其他值或未设置对应”factory”对应FACTORY_TEST_OFF)。
上面需要内核支持,不支持的话就固定为正常模式。
所以,如果内核不支持,可以直接把init.c中判断“androidboot.mode”而设置“ro.factorytest”的代码暂时屏蔽,直接用上节所说的“ro.factorytest”来决定Factory的模式。
本文分析了:
1. Android原生实现中已有的FactoryTest的框架:屏蔽了一些服务和功能;
2. 并通过下列方式就可实现工厂测试模式:
1) 写一个FactoryTest的应用;
2) 设定“ro.factorytest”系统属性,并屏蔽由内核来设定的设置,
或者
3) 通过内核启动参数“androidboot.mode”决定FactoryTest的模式。