ITestSuite

public abstract class ITestSuite
extends Object implements IRemoteTest, IDeviceTest, IBuildReceiver, ISystemStatusCheckerReceiver, IShardableTest, ITestCollector, IInvocationContextReceiver, IRuntimeHintProvider, IMetricCollectorReceiver, IConfigurationReceiver, IReportNotExecuted, ITokenRequest, ITestLoggerReceiver

java.lang.Object
   ↳ com.android.tradefed.testtype.suite.ITestSuite


Abstrakte Klasse, die zum Ausführen der Testsuite verwendet wird. Diese Klasse bildet die Grundlage für die Ausführung der Suite. Jede Implementierung kann die Liste der Tests über die Methode loadTests() definieren.

Zusammenfassung

Felder

public static final String ABI_OPTION

public static final String ACTIVE_MAINLINE_PARAMETER_KEY

public static final String MAINLINE_PARAMETER_KEY

public static final String MODULE_CHECKER_POST

public static final String MODULE_CHECKER_PRE

public static final String MODULE_METADATA_EXCLUDE_FILTER

public static final String MODULE_METADATA_INCLUDE_FILTER

public static final String PARAMETER_KEY

public static final String PREPARER_WHITELIST

public static final String PRIMARY_ABI_RUN

public static final String RANDOM_SEED

public static final String REBOOT_BEFORE_TEST

public static final String RUNNER_WHITELIST

public static final String SKIP_HOST_ARCH_CHECK

public static final String SKIP_SYSTEM_STATUS_CHECKER

public static final String TOKEN_KEY

Öffentliche Konstruktoren

ITestSuite()

Öffentliche Methoden

void addModuleMetadataExcludeFilters(MultiMap<String, String> filters)
void addModuleMetadataIncludeFilters(MultiMap<String, String> filters)
final void enableRebootBeforeTest()

Legt „reboot-before-test“ auf „true“ fest.

getAbis(ITestDevice device)

Ruft die ABIs ab, die sowohl vom Kompatibilitätstest AbiUtils.getAbisSupportedByCompatibility() als auch vom Testgerät unterstützt werden.

static getAbisForBuildTargetArchFromSuite()

Gibt die möglichen ABIs aus den TestSuiteInfo zurück.

IBuildInfo getBuildInfo()

Für die Implementierung von ITestSuite sind möglicherweise Build-Informationen erforderlich, um die Tests zu laden.

final IConfiguration getConfiguration()

Gibt den Aufruf IConfiguration zurück.

ITestLogger getCurrentTestLogger()
ITestDevice getDevice()

Holen Sie sich das Testgerät.

ModuleDefinition getDirectModule()

Gibt die direkt auszuführende ModuleDefinition zurück oder „null“, wenn noch keine vorhanden ist (wenn die ITestSuite noch nicht geSharded wurde).

IInvocationContext getInvocationContext()

Gibt den Aufrufkontext zurück.

final String getRequestedAbi()

Gibt die ABI zurück, die mit der Option „-a“ oder „--abi“ angefordert wurde.

getRequiredTokens()
long getRuntimeHint()

Gibt die voraussichtliche Laufzeit des Tests in Millisekunden zurück.

File getTestsDir()
boolean isSplitting()

Gibt „wahr“ zurück, wenn wir uns derzeit in IShardableTest.split(int) befinden.

abstract loadTests()

Abstrakte Methode zum Laden der zu laufenden Testkonfiguration.

void reportNotExecuted(ITestInvocationListener listener, String message)

Melden Sie die nicht ausgeführten Tests an den angegebenen Hauptempfänger.

void reportNotExecuted(ITestInvocationListener listener)

Melden Sie die nicht ausgeführten Tests an den angegebenen Hauptempfänger.

final void run(TestInformation testInfo, ITestInvocationListener listener)

Generische Ausführungsmethode für alle Tests, die aus loadTests() geladen wurden.

void setAbiName(String abiName)

Legen Sie den Wert von „mAbiName“ fest.

final void setAbis( abis)
void setBuild(IBuildInfo buildInfo)

void setCollectTestsOnly(boolean shouldCollectTest)

Führen Sie die Testsuite im reinen Collector-Modus aus. Dazu müssen alle Untertests diese Schnittstelle implementieren.

void setConfiguration(IConfiguration configuration)

Fügt den verwendeten IConfiguration ein.

void setDevice(ITestDevice device)

Testgerät einschleusen

void setInvocationContext(IInvocationContext invocationContext)

void setInvocationInjector(Injector injector)

Rufen Sie die aktuelle Guice-Injector aus der Aufrufabfolge ab.

void setMetricCollectors( collectors)

Hiermit wird die Liste der IMetricCollectors festgelegt, die für den Testlauf definiert sind.

void setPrimaryAbiRun(boolean primaryAbiRun)

Legen Sie den Wert für „mPrimaryAbiRun“ fest.

void setShouldMakeDynamicModule(boolean dynamicModule)

Bei verteiltem Sharding können wir keine ModuleDefinition haben, die Tests in einem Pool freigibt, da sonst das intramodulare Sharding nicht funktioniert. Daher ist es möglich, sie zu deaktivieren.

void setSystemStatusChecker( systemCheckers)

Legt die ISystemStatusCheckers aus der Konfiguration für den Test fest.

void setTestLogger(ITestLogger testLogger)

split(Integer shardCountHint, TestInformation testInfo)

Alternative Version von split(int), die auch ein TestInformation enthält, das frühe Informationen vom übergeordneten Element enthält, das die Shards erstellt.

Geschützte Methoden

createModuleListeners()

Gibt die Liste der ITestInvocationListener zurück, die für die ModuleListener-Ebene gelten.

boolean filterByConfigMetadata(IConfiguration config, MultiMap<String, String> include, MultiMap<String, String> exclude)

Wenden Sie den Metadatenfilter auf die Konfiguration an und prüfen Sie, ob sie ausgeführt werden sollte.

boolean filterByRunnerType(IConfiguration config, allowedRunners)

Wenden Sie den Filter für die Zulassungsliste für Läufer an und entfernen Sie alle Läufer, die nicht auf der Zulassungsliste stehen.

getAbisForBuildTargetArch()

Gibt die ABIs zurück, die von der Zielarchitektur des Host-Builds unterstützt werden.

getHostAbis()

Gibt die abis des Hosts zurück.

boolean shouldModuleRun(ModuleDefinition module)

Felder

ABI_OPTION

public static final String ABI_OPTION

ACTIVE_MAINLINE_PARAMETER_KEY

public static final String ACTIVE_MAINLINE_PARAMETER_KEY

MAINLINE_PARAMETER_KEY

public static final String MAINLINE_PARAMETER_KEY

MODULE_CHECKER_POST

public static final String MODULE_CHECKER_POST

MODULE_CHECKER_PRE

public static final String MODULE_CHECKER_PRE

MODULE_METADATA_EXCLUDE_FILTER

public static final String MODULE_METADATA_EXCLUDE_FILTER

MODULE_METADATA_INCLUDE_FILTER

public static final String MODULE_METADATA_INCLUDE_FILTER

PARAMETER_KEY

public static final String PARAMETER_KEY

PREPARER_WHITELIST

public static final String PREPARER_WHITELIST

PRIMARY_ABI_RUN

public static final String PRIMARY_ABI_RUN

RANDOM_SEED

public static final String RANDOM_SEED

REBOOT_BEFORE_TEST

public static final String REBOOT_BEFORE_TEST

RUNNER_WHITELIST

public static final String RUNNER_WHITELIST

SKIP_HOST_ARCH_CHECK

public static final String SKIP_HOST_ARCH_CHECK

SKIP_SYSTEM_STATUS_CHECKER

public static final String SKIP_SYSTEM_STATUS_CHECKER

TOKEN_KEY

public static final String TOKEN_KEY

Öffentliche Konstruktoren

ITestSuite

public ITestSuite ()

Öffentliche Methoden

addModuleMetadataExcludeFilters

public void addModuleMetadataExcludeFilters (MultiMap<String, String> filters)

Parameter
filters MultiMap

addModuleMetadataIncludeFilters

public void addModuleMetadataIncludeFilters (MultiMap<String, String> filters)

Parameter
filters MultiMap

enableRebootBeforeTest

public final void enableRebootBeforeTest ()

Legt „reboot-before-test“ auf „true“ fest.

getAbis

public  getAbis (ITestDevice device)

Ruft die ABIs ab, die sowohl vom Kompatibilitätstest AbiUtils.getAbisSupportedByCompatibility() als auch vom Testgerät unterstützt werden.

Parameter
device ITestDevice

Returns
Die ABIs, auf denen die Tests ausgeführt werden sollen

Ausgabe
DeviceNotAvailableException

getAbisForBuildTargetArchFromSuite

public static  getAbisForBuildTargetArchFromSuite ()

Gibt die möglichen ABIs aus den TestSuiteInfo zurück.

Returns

getBuildInfo

public IBuildInfo getBuildInfo ()

Für die Implementierung von ITestSuite sind möglicherweise Build-Informationen erforderlich, um die Tests zu laden.

Returns
IBuildInfo

getConfiguration

public final IConfiguration getConfiguration ()

Gibt den Aufruf IConfiguration zurück.

Returns
IConfiguration

getCurrentTestLogger

public ITestLogger getCurrentTestLogger ()

Returns
ITestLogger

getDevice

public ITestDevice getDevice ()

Holen Sie sich das Testgerät.

Returns
ITestDevice die ITestDevice

getDirectModule

public ModuleDefinition getDirectModule ()

Gibt die direkt auszuführende ModuleDefinition zurück oder „null“, wenn noch keine vorhanden ist (wenn die ITestSuite noch nicht geSharded wurde).

Returns
ModuleDefinition

getInvocationContext

public IInvocationContext getInvocationContext ()

Gibt den Aufrufkontext zurück.

Returns
IInvocationContext

getRequestedAbi

public final String getRequestedAbi ()

Gibt die ABI zurück, die mit der Option „-a“ oder „--abi“ angefordert wurde.

Returns
String

getRequiredTokens

public  getRequiredTokens ()

Returns

getRuntimeHint

public long getRuntimeHint ()

Gibt die voraussichtliche Laufzeit des Tests in Millisekunden zurück. Die Zeit wird für das Load Balancing der ge shardeten Ausführung verwendet.

Returns
long

getTestsDir

public File getTestsDir ()

Returns
File

isSplitting

public boolean isSplitting ()

Gibt „wahr“ zurück, wenn wir uns derzeit in IShardableTest.split(int) befinden.

Returns
boolean

loadTests

public abstract  loadTests ()

Abstrakte Methode zum Laden der zu laufenden Testkonfiguration. Jeder Test wird durch eine IConfiguration und einen eindeutigen Namen definiert, unter dem die Ergebnisse erfasst werden.

Returns

reportNotExecuted

public void reportNotExecuted (ITestInvocationListener listener, 
                String message)

Melden Sie die nicht ausgeführten Tests an den angegebenen Hauptempfänger. Sie sollten mit der Meldung NOT_EXECUTED_FAILURE als fehlgeschlagen gemeldet werden.

Parameter
listener ITestInvocationListener: Der Haupt-Listener, an den die nicht ausgeführten Ergebnisse gesendet werden sollen.

message String: Die Nachricht, die dem nicht ausgeführten Fehler zugeordnet werden soll.

reportNotExecuted

public void reportNotExecuted (ITestInvocationListener listener)

Melden Sie die nicht ausgeführten Tests an den angegebenen Hauptempfänger. Sie sollten mit der Meldung NOT_EXECUTED_FAILURE als fehlgeschlagen gemeldet werden.

Parameter
listener ITestInvocationListener: Der Haupt-Listener, an den die nicht ausgeführten Ergebnisse gesendet werden sollen.

Homerun

public final void run (TestInformation testInfo, 
                ITestInvocationListener listener)

Generische Ausführungsmethode für alle Tests, die aus loadTests() geladen wurden.

Parameter
testInfo TestInformation

listener ITestInvocationListener

Ausgabe
DeviceNotAvailableException

setAbiName

public void setAbiName (String abiName)

Legen Sie den Wert von „mAbiName“ fest.

Parameter
abiName String

setAbis

public final void setAbis ( abis)

Parameter
abis

setBuild

public void setBuild (IBuildInfo buildInfo)

Parameter
buildInfo IBuildInfo

setCollectTestsOnly

public void setCollectTestsOnly (boolean shouldCollectTest)

Führen Sie die Testsuite im reinen Collector-Modus aus. Dazu müssen alle Untertests diese Schnittstelle implementieren.

setConfiguration

public void setConfiguration (IConfiguration configuration)

Fügt den verwendeten IConfiguration ein.

Parameter
configuration IConfiguration

setDevice

public void setDevice (ITestDevice device)

Testgerät einschleusen

Parameter
device ITestDevice: der zu verwendende ITestDevice

setInvocationContext

public void setInvocationContext (IInvocationContext invocationContext)

Parameter
invocationContext IInvocationContext

setInvocationInjector

public void setInvocationInjector (Injector injector)

Rufen Sie die aktuelle Guice-Injector aus der Aufrufabfolge ab. Damit sollte es möglich sein, die Objektinjektion von Modulen fortzusetzen.

Parameter
injector Injector

setMetricCollectors

public void setMetricCollectors ( collectors)

Hiermit wird die Liste der IMetricCollectors festgelegt, die für den Testlauf definiert sind.

Parameter
collectors

setPrimaryAbiRun

public void setPrimaryAbiRun (boolean primaryAbiRun)

Legen Sie den Wert für „mPrimaryAbiRun“ fest.

Parameter
primaryAbiRun boolean

setShouldMakeDynamicModule

public void setShouldMakeDynamicModule (boolean dynamicModule)

Bei verteiltem Sharding können wir keine ModuleDefinition haben, die Tests in einem Pool freigibt, da sonst das intramodulare Sharding nicht funktioniert. Daher ist es möglich, sie zu deaktivieren.

Parameter
dynamicModule boolean

setSystemStatusChecker

public void setSystemStatusChecker ( systemCheckers)

Legt die ISystemStatusCheckers aus der Konfiguration für den Test fest.

Parameter
systemCheckers

setTestLogger

public void setTestLogger (ITestLogger testLogger)

Parameter
testLogger ITestLogger

aufteilen

public  split (Integer shardCountHint, 
                TestInformation testInfo)

Alternative Version von split(int), die auch ein TestInformation enthält, das frühe Informationen vom übergeordneten Element enthält, das die Shards erstellt. Das ist nützlich, wenn beim Sharding auf Geräte- oder Build-Informationen zugegriffen werden muss.

Parameter
shardCountHint Integer: die Anzahl der Shards, die versucht wurden.

testInfo TestInformation: Das übergeordnete TestInformation

Returns
eine Sammlung von Teiltests, die separat ausgeführt werden sollen, oder null, wenn der Test derzeit nicht geShardet werden kann

Geschützte Methoden

createModuleListeners

protected  createModuleListeners ()

Gibt die Liste der ITestInvocationListener zurück, die für die ModuleListener-Ebene gelten. Diese Listener werden für jedes Modul wiederverwendet, sie werden nicht neu instanziiert. Daher sollten sie keinen internen Status annehmen.

Returns

filterByConfigMetadata

protected boolean filterByConfigMetadata (IConfiguration config, 
                MultiMap<String, String> include, 
                MultiMap<String, String> exclude)

Wenden Sie den Metadatenfilter auf die Konfiguration an und prüfen Sie, ob sie ausgeführt werden sollte.

Parameter
config IConfiguration: Die zu bewertende IConfiguration.

include MultiMap: den Metadaten-Inklusionsfilter

exclude MultiMap: den Metadaten-Ausschlussfilter

Returns
boolean „True“, wenn das Modul ausgeführt werden soll, andernfalls „False“.

filterByRunnerType

protected boolean filterByRunnerType (IConfiguration config, 
                 allowedRunners)

Wenden Sie den Filter für die Zulassungsliste für Läufer an und entfernen Sie alle Läufer, die nicht auf der Zulassungsliste stehen. Wenn eine Konfiguration mehrere Auslöser hat, werden einige möglicherweise entfernt, die Konfiguration wird aber trotzdem ausgeführt.

Parameter
config IConfiguration: Die zu bewertende IConfiguration.

allowedRunners : Die aktuelle Zulassungsliste für Runner.

Returns
boolean „True“, wenn das Konfigurationsmodul ausgeführt werden darf, andernfalls „false“.

getAbisForBuildTargetArch

protected  getAbisForBuildTargetArch ()

Gibt die ABIs zurück, die von der Zielarchitektur des Host-Builds unterstützt werden. Wird für Tests freigegeben.

Returns

getHostAbis

protected  getHostAbis ()

Gibt die abis des Hosts zurück.

Returns

shouldModuleRun

protected boolean shouldModuleRun (ModuleDefinition module)

Parameter
module ModuleDefinition

Returns
boolean