一般单元测试用在后台的 API,但是如果不巧,要做客户端的 sdk,好像后台的这个单元测试的流程,也是可以用的,下面来看看怎么配置 android sdk 的单元测试
build.gradle 配置
dependencies {
// .....
testImplementation 'junit:junit:4.12'
testImplementation "androidx.test:core:1.1.1"
testImplementation "androidx.test.ext:junit:1.1.1"
testImplementation "org.robolectric:robolectric:4.2.1"
testImplementation 'com.android.support.test:runner:0.5'
testImplementation 'com.android.support.test:rules:0.5'
testImplementation 'org.mockito:mockito-core:2.19.0'
}
测试用例类 ExampleUnitTest.java
测试用例
@Config(sdk = 28)
@RunWith(AndroidJUnit4.class)
public class ExampleUnitTest {
@Test
public void testCase() {
Context context = ApplicationProvider.getApplicationContext();
View.OnClickListener mqttActionCallBack = mock(View.OnClickListener.class);
assertEquals(4, 2 + 2);
}
}
测试用例运行效果
附加说明
细心的你,应该发现了为什么要增加 @Config(sdk = XX) 这个注解呢,这里是为了修复下面这个错误
ExampleUnitTest.testCase: Package targetSdkVersion=29 > maxSdkVersion=28
调整 build.gradle 中 targetSdkVersion 这个参数也是可以的,另外一种改法就是使用 @Config(sdk = XX) 这个注解,来限定测试用例的依赖的 sdk 版本
那有人又会问了 @RunWith(AndroidJUnit4.class) 又是干嘛的,好吧我们先看看没有这个注解跑出来是什么效果
java.lang.IllegalStateException: No instrumentation registered! Must run under a registering instrumentation.
at androidx.test.platform.app.InstrumentationRegistry.getInstrumentation(InstrumentationRegistry.java:45)
at androidx.test.core.app.ApplicationProvider.getApplicationContext(ApplicationProvider.java:41)
at com.qcloud.iot_sdk_java.ExampleUnitTest.testCase(ExampleUnitTest.java:29)
测试用例的 29 行对应的是获取上下文
Context context = ApplicationProvider.getApplicationContext();
现在大家应该明白了吧,这样可以限定是 android 的单元测试,后续就可以获取 android 层面经常需要使用的上下文
|