BasePostProcessor
public
abstract
class
BasePostProcessor
extends Object
implements
IPostProcessor
java.lang.Object | |
↳ | com.android.tradefed.postprocessor.BasePostProcessor |
すべての実装で拡張する必要があるベースの IPostProcessor
。最終結果レポーターより前に、後処理メソッドが呼び出されるようにします。
概要
パブリック コンストラクタ | |
---|---|
BasePostProcessor()
|
パブリック メソッド | |
---|---|
final
ITestInvocationListener
|
init(ITestInvocationListener listener)
ポストプロセッサの初期化ステップ。 |
final
void
|
invocationEnded(long elapsedTime)
呼び出しが正常に終了したか、なんらかのエラー条件が原因で終了したかを報告します。 |
final
void
|
invocationFailed(FailureDescription failure)
エラー条件により不完全な呼び出しを報告します。 |
final
void
|
invocationFailed(Throwable cause)
エラー条件により不完全な呼び出しを報告します。 |
void
|
invocationSkipped(SkipReason reason)
呼び出しをスキップ済みとして報告する |
final
void
|
invocationStarted(IInvocationContext context)
転送用の呼び出しリスナー |
final
boolean
|
isDisabled()
オブジェクト全体が無効になっている場合(セットアップとテイクダウンの両方をスキップする場合)、true を返します。 |
final
void
|
logAssociation(String dataName, LogFile logFile)
場合によっては、ログをテストケースに強く関連付ける必要があります。しかし、直接の ログとテストの関連付けを更新します。 |
|
processAllTestMetricsAndLogs(ListMultimap<String, MetricMeasurement.Metric> allTestMetrics,
このメソッドを実装して、すべてのテストの指標とログを集計します。 |
abstract
|
processRunMetricsAndLogs(
このメソッドを実装して、既存の指標とログから一連の新しい指標を生成します。 |
|
processTestMetricsAndLogs(TestDescription testDescription,
このメソッドを実装して、各テストの指標とログをポスト処理します。 |
final
void
|
setLogSaver(ILogSaver logSaver)
実装者がファイルを保存できるように |
void
|
setUp()
子ポスト プロセッサでこのメソッドをオーバーライドして、テストの実行前に初期化します。 |
final
void
|
testAssumptionFailure(TestDescription test, String trace)
アトミック テストが false の条件を前提としていることを報告するフラグが立てられたときに呼び出されます。 |
final
void
|
testAssumptionFailure(TestDescription test, FailureDescription failure)
アトミック テストで、条件が false であるとフラグが立てられたときに呼び出されます |
final
void
|
testEnded(TestDescription test, long endTime,
終了時間を直接指定できる |
final
void
|
testEnded(TestDescription test,
個々のテストケースの実行終了を報告します。 |
final
void
|
testFailed(TestDescription test, FailureDescription failure)
個々のテストケースの失敗を報告します。 |
final
void
|
testFailed(TestDescription test, String trace)
個々のテストケースの失敗を報告します。 |
final
void
|
testIgnored(TestDescription test)
テストが実行されないときに呼び出されます。通常はテストメソッドに org.junit.Ignore を使用します。 |
final
void
|
testLog(String dataName, LogDataType dataType, InputStreamSource dataStream)
このメソッドは、PostProcessor の実装からファイルをログに記録するために使用します。 |
final
void
|
testLogSaved(String dataName, LogDataType dataType, InputStreamSource dataStream, LogFile logFile)
テストログが保存されたときに呼び出されます。 |
final
void
|
testModuleEnded()
モジュール実行の終了をレポートします。 |
final
void
|
testModuleStarted(IInvocationContext moduleContext)
モジュールの実行開始を報告します。 |
final
void
|
testRunEnded(long elapsedTime,
テスト実行の終了をレポートします。 |
final
void
|
testRunFailed(FailureDescription failure)
|
final
void
|
testRunFailed(String errorMessage)
致命的なエラーが発生したため、レポートのテスト実行が完了しませんでした。 |
final
void
|
testRunStarted(String runName, int testCount, int attemptNumber)
テスト実行の開始を報告します。 |
final
void
|
testRunStarted(String runName, int testCount)
テスト実行コールバック |
final
void
|
testRunStarted(String runName, int testCount, int attemptNumber, long startTime)
テスト実行の開始を報告します。 |
final
void
|
testRunStopped(long elapsedTime)
ユーザー リクエストが原因で、テスト実行が完了前に停止したことを報告します。 |
final
void
|
testSkipped(TestDescription test, SkipReason reason)
テストがスキップされ、通常は予期されない理由でテストが実行されなかった場合に呼び出されます。 |
final
void
|
testStarted(TestDescription test, long startTime)
|
final
void
|
testStarted(TestDescription test)
テストケースのコールバック |
保護されたメソッド | |
---|---|
void
|
cleanUp()
|
MetricMeasurement.DataType
|
getMetricType()
必要に応じて、このメソッドをオーバーライドして指標タイプを変更します。 |
String
|
getRunName()
|
パブリック コンストラクタ
BasePostProcessor(BasePostProcessor)
public BasePostProcessor ()
パブリック メソッド
init
public final ITestInvocationListener init (ITestInvocationListener listener)
ポストプロセッサの初期化ステップ。テストのコールバックの前に必ず呼び出されます。
パラメータ | |
---|---|
listener |
ITestInvocationListener |
戻り値 | |
---|---|
ITestInvocationListener |
invocationEnded
public final void invocationEnded (long elapsedTime)
呼び出しが正常に終了したか、なんらかのエラー状態が原因で終了したかを報告します。
TradeFederation フレームワークによって自動的に呼び出されます。
パラメータ | |
---|---|
elapsedTime |
long : 呼び出しの所要時間(ミリ秒単位) |
invocationFailed
public final void invocationFailed (FailureDescription failure)
エラー状態が原因で呼び出しが完了しなかったことを報告します。
TradeFederation フレームワークによって自動的に呼び出されます。
パラメータ | |
---|---|
failure |
FailureDescription : 失敗の原因を説明する FailureDescription |
invocationFailed
public final void invocationFailed (Throwable cause)
エラー状態が原因で呼び出しが完了しなかったことを報告します。
TradeFederation フレームワークによって自動的に呼び出されます。
パラメータ | |
---|---|
cause |
Throwable : 失敗の Throwable 原因 |
invocationSkipped
public void invocationSkipped (SkipReason reason)
呼び出しをスキップとして報告する
パラメータ | |
---|---|
reason |
SkipReason |
invocationStarted
public final void invocationStarted (IInvocationContext context)
転送用の呼び出しリスナー
パラメータ | |
---|---|
context |
IInvocationContext : 呼び出しに関する情報 |
isDisabled
public final boolean isDisabled ()
オブジェクト全体が無効になっている場合(セットアップとテイクダウンの両方をスキップ)、true を返します。それ以外の場合は False です。
戻り値 | |
---|---|
boolean |
logAssociation
public final void logAssociation (String dataName, LogFile logFile)
場合によっては、ログとテストケースとの関連性を強くする必要がありますが、
直線の testLogSaved(String, com.android.tradefed.result.LogDataType, com.android.tradefed.result.InputStreamSource, com.android.tradefed.result.LogFile)
です。
できません。したがって、このコールバックを使用すると、
明示的に指定することもできます。
ログとテストの関連付けを更新します。このメソッドがテスト中に呼び出された場合は、ログはテストに属します。それ以外の場合は、実行ログになります。
パラメータ | |
---|---|
dataName |
String : データの名前 |
logFile |
LogFile : 前にロギングされ、テストケースに関連付ける必要がある LogFile 。 |
processAllTestMetricsAndLogs
publicprocessAllTestMetricsAndLogs (ListMultimap<String, MetricMeasurement.Metric> allTestMetrics, allTestLogs)
このメソッドを実装して、すべてのテストの指標とログを集計します。指標の取得元: このメソッドは実行指標のレポーターになります。新しく生成された指標のみを 一意のキー名で返されます(既存のキーとの競合は許容されません)。
パラメータ | |
---|---|
allTestMetrics |
ListMultimap : 指標名でグループ化された各テストの指標を格納する HashMultimap。 |
allTestLogs |
: データ名をキーとして持つ、各テストのログファイルのマップを保存するマップ。
各テストの TestDescription をキーとして使用します。 |
戻り値 | |
---|---|
|
すべてのテスト指標から新しく生成された指標のセット。 |
processRunMetricsAndLogs
public abstractprocessRunMetricsAndLogs ( rawMetrics, runLogs)
このメソッドを実装すると、既存の指標とログから一連の新しい指標を生成できます。新しく生成された指標のみが、一意のキー名( 既存の鍵との衝突は許容されます)。
パラメータ | |
---|---|
rawMetrics |
: 実行に使用できる元の指標のセット。 |
runLogs |
: テスト実行のログファイルのセット。 |
戻り値 | |
---|---|
|
実行の指標から新しく生成された指標のセット。 |
processTestMetricsAndLogs
publicprocessTestMetricsAndLogs (TestDescription testDescription, testMetrics, testLogs)
このメソッドを実装して、各テストの指標とログをポスト処理します。新しく生成された指標のみを返す必要があります。キー名は一意にする必要があります(既存のキーとの競合は許可されません)。
パラメータ | |
---|---|
testDescription |
TestDescription : テストを記述する TestDescription オブジェクト。 |
testMetrics |
: テストの指標セット。 |
testLogs |
: テスト中にログに記録されたファイルのセット。 |
戻り値 | |
---|---|
|
テスト指標から新しく生成された指標のセット。 |
setLogSaver
public final void setLogSaver (ILogSaver logSaver)
実装者がファイルを保存できるように ILogSaver
を設定します。
パラメータ | |
---|---|
logSaver |
ILogSaver : ILogSaver |
セットアップ
public void setUp ()
子ポスト プロセッサでこのメソッドをオーバーライドして、テストの実行前に初期化します。
testAssumptionFailure
public final void testAssumptionFailure (TestDescription test, String trace)
アトミック テストが false の条件を前提としていることを報告するフラグが立てられたときに呼び出されます。
パラメータ | |
---|---|
test |
TestDescription : テストを識別します。 |
trace |
String : 障害のスタック トレース |
testAssumptionFailure
public final void testAssumptionFailure (TestDescription test, FailureDescription failure)
アトミック テストが false の条件を前提としていることを報告するフラグが立てられたときに呼び出されます。
パラメータ | |
---|---|
test |
TestDescription : テストを識別します。 |
failure |
FailureDescription : エラーとそのコンテキストを記述する FailureDescription 。 |
testEnded
public final void testEnded (TestDescription test, long endTime,testMetrics)
終了時間を指定できる ERROR(/#testEnded(com.android.tradefed.result.TestDescription,Map))
の代替
直接渡されます。正確に測定するには、testStarted(com.android.tradefed.result.TestDescription, long)
と組み合わせてください。
パラメータ | |
---|---|
test |
TestDescription : テストを識別します。 |
endTime |
long : テストが終了した時刻(System.currentTimeMillis() で測定) |
testMetrics |
: 出力された指標の ERROR(/Map) |
testEnded
public final void testEnded (TestDescription test,testMetrics)
個々のテストケースの実行終了を報告します。
testFailed(TestDescription, FailureDescription)
が呼び出されなかった場合、このテストは合格です。また、テストケースの実行中に出力された Key-Value 指標も返します。
パラメータ | |
---|---|
test |
TestDescription : テストを識別します。 |
testMetrics |
: 出力された指標の ERROR(/Map) |
testFailed
public final void testFailed (TestDescription test, FailureDescription failure)
個々のテストケースの失敗を報告します。
testStarted と testEnded の間で呼び出されます。
パラメータ | |
---|---|
test |
TestDescription : テストを識別します。 |
failure |
FailureDescription : エラーとそのコンテキストを記述する FailureDescription 。 |
testFailed
public final void testFailed (TestDescription test, String trace)
個々のテストケースの失敗を報告します。
testStarted と testEnded の間で呼び出されます。
パラメータ | |
---|---|
test |
TestDescription : テストを識別します。 |
trace |
String : 障害のスタック トレース |
testIgnored
public final void testIgnored (TestDescription test)
テストが実行されないときに呼び出されます。通常はテストメソッドに org.junit.Ignore を使用します。
パラメータ | |
---|---|
test |
TestDescription : テストを識別します。 |
testLog
public final void testLog (String dataName, LogDataType dataType, InputStreamSource dataStream)
このメソッドを使用して、PostProcessor 実装からファイルをログに記録します。
パラメータ | |
---|---|
dataName |
String : String でデータのわかりやすい名前。例:「device_logcat」。備考
dataName は呼び出しごとに一意であってはなりません。つまり 実装担当者は
同じ dataName を持つ複数の呼び出し |
dataType |
LogDataType : データの LogDataType |
dataStream |
InputStreamSource : データの InputStreamSource 。実装者は createInputStream を呼び出してデータの読み取りを開始し、完了したら結果の InputStream を必ず閉じる必要があります。呼び出し元は、データソースが確実に
存在し、testLog メソッドが完了するまでアクセスできます。 |
testLogSaved
public final void testLogSaved (String dataName, LogDataType dataType, InputStreamSource dataStream, LogFile logFile)
テストログが保存されたときに呼び出されます。
ITestInvocationListener#testLog(String, LogDataType,
InputStreamSource)
の代わりに使用する必要があります。
パラメータ | |
---|---|
dataName |
String : String でデータのわかりやすい名前。例:「device_logcat」。注: dataName は呼び出しごとに一意ではない場合があります。つまり、実装者は同じ dataName で複数の呼び出しを処理できる必要があります。 |
dataType |
LogDataType : データの LogDataType |
dataStream |
InputStreamSource : データの InputStreamSource 。実装担当者は
createInputStream を実装してデータの読み取りを開始し、
InputStream。 |
logFile |
LogFile : 保存されたファイルのメタデータを含む LogFile 。 |
testModuleEnded
public final void testModuleEnded ()
モジュールの実行の終了を報告します。
testModuleStarted
public final void testModuleStarted (IInvocationContext moduleContext)
実行中のモジュールの開始を報告します。このコールバックは testModuleEnded()
に関連付けられており、シーケンスでは省略可能です。これは、Pod を使用する実行時にのみ
スイートベースのランナーです。
パラメータ | |
---|---|
moduleContext |
IInvocationContext : モジュールの IInvocationContext 。 |
testRunEnded
public final void testRunEnded (long elapsedTime,runMetrics)
テスト実行の終了をレポートします。
パラメータ | |
---|---|
elapsedTime |
long : デバイスで報告された経過時間(ミリ秒単位) |
runMetrics |
: テスト実行の終了時にレポートされる Key-Value ペア |
testRunFailed
public final void testRunFailed (FailureDescription failure)
FailureDescription
で説明されているエラーが原因で、テスト実行が完了しなかったことを報告します。
パラメータ | |
---|---|
failure |
FailureDescription : 障害とそのコンテキストを記述する FailureDescription 。 |
testRunFailed
public final void testRunFailed (String errorMessage)
致命的なエラーのため、テスト実行を完了できなかったことをレポートします。
パラメータ | |
---|---|
errorMessage |
String : 実行失敗の理由を説明する String 。 |
testRunStarted
public final void testRunStarted (String runName, int testCount, int attemptNumber)
テスト実行の開始を報告します。
パラメータ | |
---|---|
runName |
String : テスト実行名 |
testCount |
int : テスト実行のテスト数の合計 |
attemptNumber |
int : 同じ runName の異なる試行を識別する注文番号
実行されるリソースのことですtryNumber の値は、0 から始まる番号で、毎回増分する必要があります。
発生します。例:テストは詳細に 3 回再試行され、合計 4 回試行される必要がある
同じ runName で実行され、AttemptNumber の値は 0 ~ 3 です。 |
testRunStarted
public final void testRunStarted (String runName, int testCount)
テスト実行のコールバック
パラメータ | |
---|---|
runName |
String : テスト実行名 |
testCount |
int : テスト実行のテスト数の合計 |
testRunStarted
public final void testRunStarted (String runName, int testCount, int attemptNumber, long startTime)
テスト実行の開始を報告します。
パラメータ | |
---|---|
runName |
String : テスト実行名 |
testCount |
int : テスト実行のテスト数の合計 |
attemptNumber |
int : オーダー番号。同じ runName を複数回実行する際の試行を識別します。tryNumber の値はインデックスが 0 で、
発生します。例:テストを細かく 3 回再試行します。合計 4 回の実行が必要です。
同じ runName の下にあり、AttemptNumber は 0 ~ 3 です。 |
startTime |
long : 実行が開始された時刻(System.currentTimeMillis() で測定) |
testRunStopped
public final void testRunStopped (long elapsedTime)
ユーザー リクエストが原因で、テスト実行が完了前に停止したことを報告します。
TODO: 現在は使用されていないため、削除を検討してください
パラメータ | |
---|---|
elapsedTime |
long : デバイスが報告した経過時間(ミリ秒単位) |
testSkipped
public final void testSkipped (TestDescription test, SkipReason reason)
通常想定されない理由でテストがスキップされ、実行されなかった場合に呼び出されます。これらのテストは、適切な実行を行うために再試行されます。
パラメータ | |
---|---|
test |
TestDescription : テストを識別します。 |
reason |
SkipReason : SkipReason |
testStarted
public final void testStarted (TestDescription test, long startTime)
testStarted(com.android.tradefed.result.TestDescription)
に代わるもので、テストがいつ実行されたかも指定します。
開始され、正確な測定のために ERROR(/#testEnded(com.android.tradefed.result.TestDescription,long,Map))
と組み合わせて使用されます。
パラメータ | |
---|---|
test |
TestDescription : テストを識別します。 |
startTime |
long : テストが開始された時刻(System.currentTimeMillis() で測定) |
testStarted
public final void testStarted (TestDescription test)
テストケースのコールバック
パラメータ | |
---|---|
test |
TestDescription : テストを識別します。 |
保護されたメソッド
cleanUp
protected void cleanUp ()
getMetricType
protected MetricMeasurement.DataType getMetricType ()
必要に応じて、このメソッドをオーバーライドして指標タイプを変更します。デフォルトでは あります。
戻り値 | |
---|---|
MetricMeasurement.DataType |
getRunName
protected String getRunName ()
戻り値 | |
---|---|
String |