我有一个读取短信的应用程序。该应用程序在调试时工作正常,但在使用 android 仪器测试对其进行测试时,会抛出以下错误
java.lang.SecurityException: Permission Denial: reading com.android.providers.telephony.SmsProvider
这是我的测试用例
@RunWith(AndroidJUnit4.class)
public class SmsFetcherTest {
@Test
public void fetchTenSms() throws Exception {
// Context of the app under test.
Context appContext = InstrumentationRegistry.getContext();
// Fails anyway.
// assertTrue(ContextCompat.checkSelfPermission(appContext,
// "android.permission.READ_SMS") == PackageManager.PERMISSION_GRANTED);
List<Sms> tenSms = new SmsFetcher(appContext)
.limit(10)
.get();
assertEquals(10, tenSms.size());
}
}
我是仪器测试的新手。这是正确的方法吗?
或者我错过了什么?
GrantPermissionRule
。方法如下:
将以下依赖项添加到
app/build.gradle
:
dependencies {
...
androidTestImplementation 'androidx.test:rules:1.4.0'
}
现在将以下内容添加到您的
InstrumentedTest
类中:
import androidx.test.rule.GrantPermissionRule;
public class InstrumentedTest {
@Rule
public GrantPermissionRule mRuntimePermissionRule = GrantPermissionRule.grant(Manifest.permission.READ_SMS);
...
}
您可以按如下方式授予权限:
@RunWith(AndroidJUnit4.class)
public class MyInstrumentationTest {
@Rule
public GrantPermissionRule permissionRule = GrantPermissionRule.grant(Manifest.permission.READ_SMS);
...
}
如果您对仪器类使用继承,您应该在父类中编写
@get:Rule
。
地点:
import androidx.test.rule.GrantPermissionRule
@RunWith(AndroidJUnit4::class)
open class SomeTest {
@get:Rule
val permissionRule: GrantPermissionRule = GrantPermissionRule.grant(
Manifest.permission.ACCESS_FINE_LOCATION,
Manifest.permission.ACCESS_COARSE_LOCATION)
如果您在 Android
例外的设备上添加 < Q or permission that doesn't exist in AndroidManifest you will get
ACCESS_BACKGROUND_LOCATION
。
为了可重用性,我创建了一个界面:
interface WriteExternalPermission {
@get:Rule val writeExternalPermission: GrantPermissionRule
get() = GrantPermissionRule.grant(Manifest.permission.WRITE_EXTERNAL_STORAGE)
}
您可以在需要此权限的测试类中实现它。