ITestLifeCycleReceiver
public
interface
ITestLifeCycleReceiver
| com.android.tradefed.result.ITestLifeCycleReceiver |
在插桩测试运行期间接收事件通知。
以 org.junit.runner.notification.RunListener 为蓝本
调用顺序如下:
- testRunStarted
- testStarted
- [testFailed]
- [testAssumptionFailure]
- [testIgnored]
- testEnded
- ....
- [testRunFailed]
- testRunEnded
摘要
公共方法 | |
|---|---|
default
void
|
testAssumptionFailure(TestDescription test, String trace)
当原子测试标记其假设的条件为 false 时调用 |
default
void
|
testAssumptionFailure(TestDescription test, FailureDescription failure)
当原子测试标记其假设的条件为 false 时调用 |
default
void
|
testEnded(TestDescription test, long endTime,
|
default
void
|
testEnded(TestDescription test,
报告单个测试用例的执行结束时间。 |
default
void
|
testFailed(TestDescription test, FailureDescription failure)
报告单个测试用例的失败。 |
default
void
|
testFailed(TestDescription test, String trace)
报告单个测试用例的失败。 |
default
void
|
testIgnored(TestDescription test)
当测试不会运行时(通常是因为测试方法使用 org.junit.Ignore 注释)调用。 |
default
void
|
testRunEnded(long elapsedTimeMillis,
报告测试运行结束。 |
default
void
|
testRunFailed(FailureDescription failure)
报告测试运行因 |
default
void
|
testRunFailed(String errorMessage)
报告测试运行因严重错误而未能完成。 |
default
void
|
testRunStarted(String runName, int testCount, int attemptNumber)
报告测试运行的开始。 |
default
void
|
testRunStarted(String runName, int testCount)
报告测试运行的开始。 |
default
void
|
testRunStarted(String runName, int testCount, int attemptNumber, long startTime)
报告测试运行的开始。 |
default
void
|
testRunStopped(long elapsedTime)
报告测试运行因用户请求而在完成前停止。 |
default
void
|
testSkipped(TestDescription test, SkipReason reason)
当测试因通常不预期的原因而被跳过且未执行时调用。 |
default
void
|
testStarted(TestDescription test, long startTime)
|
default
void
|
testStarted(TestDescription test)
报告单个测试用例的开始。 |
公共方法
testAssumptionFailure
public void testAssumptionFailure (TestDescription test, String trace)
当原子测试标记其假设的条件为 false 时调用
| 参数 | |
|---|---|
test |
TestDescription:用于标识测试 |
trace |
String:失败的堆栈轨迹 |
testAssumptionFailure
public void testAssumptionFailure (TestDescription test, FailureDescription failure)
当原子测试标记其假设的条件为 false 时调用
| 参数 | |
|---|---|
test |
TestDescription:用于标识测试 |
failure |
FailureDescription:描述失败及其上下文的 FailureDescription。 |
testEnded
public 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 void testEnded (TestDescription test,testMetrics)
报告单个测试用例的执行结束时间。
如果未调用 testFailed(TestDescription, FailureDescription),则此测试通过。还会返回测试用例执行期间可能发出的任何键值指标。
| 参数 | |
|---|---|
test |
TestDescription:用于标识测试 |
testMetrics |
:所发出指标的 ERROR(/Map) |
testFailed
public void testFailed (TestDescription test, FailureDescription failure)
报告单个测试用例的失败。
将在 testStarted 和 testEnded 之间调用。
| 参数 | |
|---|---|
test |
TestDescription:用于标识测试 |
failure |
FailureDescription:描述失败及其上下文的 FailureDescription。 |
testFailed
public void testFailed (TestDescription test, String trace)
报告单个测试用例的失败。
将在 testStarted 和 testEnded 之间调用。
| 参数 | |
|---|---|
test |
TestDescription:用于标识测试 |
trace |
String:失败的堆栈轨迹 |
testIgnored
public void testIgnored (TestDescription test)
当测试不会运行时(通常是因为测试方法使用 org.junit.Ignore 注释)调用。
| 参数 | |
|---|---|
test |
TestDescription:用于标识测试 |
testRunEnded
public void testRunEnded (long elapsedTimeMillis,
runMetrics) 报告测试运行结束。
| 参数 | |
|---|---|
elapsedTimeMillis |
long:设备报告的已用时间,以毫秒为单位 |
runMetrics |
:在测试运行结束时报告的键值对 |
testRunFailed
public void testRunFailed (FailureDescription failure)
报告测试运行因 FailureDescription 描述的失败而未能完成。
| 参数 | |
|---|---|
failure |
FailureDescription:描述失败及其上下文的 FailureDescription。 |
testRunFailed
public void testRunFailed (String errorMessage)
报告测试运行因出现严重错误而未能完成。
| 参数 | |
|---|---|
errorMessage |
String:描述运行失败原因的 String。 |
testRunStarted
public void testRunStarted (String runName,
int testCount,
int attemptNumber)报告测试运行的开始。
| 参数 | |
|---|---|
runName |
String:测试运行名称 |
testCount |
int:测试运行中的测试总数 |
attemptNumber |
int:用于标识多次运行的同一 runName 的不同尝试的订单号。attemptNumber 从 0 开始,每次新运行时都会递增。例如,如果某项测试进行了 3 次精细重试,则在同一 runName 下,该测试总共应运行 4 次,且 attemptNumber 从 0 到 3。 |
testRunStarted
public void testRunStarted (String runName,
int testCount)报告测试运行的开始。
| 参数 | |
|---|---|
runName |
String:测试运行名称 |
testCount |
int:测试运行中的测试总数 |
testRunStarted
public void testRunStarted (String runName,
int testCount,
int attemptNumber,
long startTime)报告测试运行的开始。
| 参数 | |
|---|---|
runName |
String:测试运行名称 |
testCount |
int:测试运行中的测试总数 |
attemptNumber |
int:用于标识多次运行的同一 runName 的不同尝试的订单号。attemptNumber 从 0 开始,每次新运行都会递增。例如,如果某项测试进行了 3 次精细重试,则在同一 runName 下,该测试总共应运行 4 次,且 attemptNumber 从 0 到 3。 |
startTime |
long:运行开始时间,通过 System.currentTimeMillis() 测量 |
testRunStopped
public void testRunStopped (long elapsedTime)
报告测试运行因用户请求而在完成前停止。
TODO:目前未使用,考虑移除
| 参数 | |
|---|---|
elapsedTime |
long:设备报告的已用时间,以毫秒为单位 |
testSkipped
public void testSkipped (TestDescription test, SkipReason reason)
当测试因通常不预期的原因而被跳过且未执行时调用。系统将尝试重试这些测试,以尝试获得正确的执行结果。
| 参数 | |
|---|---|
test |
TestDescription:用于标识测试 |
reason |
SkipReason:SkipReason |
testStarted
public 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 void testStarted (TestDescription test)
报告单个测试用例的开始。旧版接口,应尽可能使用 testStarted(com.android.tradefed.result.TestDescription)。
| 参数 | |
|---|---|
test |
TestDescription:用于标识测试 |