我有一个普通的方法,而且我想嘲笑一个本地方法的类:
public class MyClass {
public int regularMethod() { ... }
public void native myNativeMethod();
}
我使用Robolectric来测试我的应用程序,我试图找出一种方法来模拟使用这些方法的自定义阴影类 。 这里是我的影子类:
@Implements(MyClass.class)
public class MyShadowClass {
@Implementation
public int regularMethod { return 0; }
@Implementation
public void nativeMethod { ... }
}
下面是我的测试:
@RunWith(RobolectricTestRunner.class)
@Config(manifest = Config.NONE)
public class MyTest {
@Test
@Config(shadows = { MyShadowClass.class })
public void test() {
MyClass obj = new MyClass();
Assert.assertEquals(obj.regularMethod(), 0);
}
}
这是行不通的,因为我以为。 嘲弄本地方法可能与暗影类的延展,但我认为,以这种方式使用自定义的影子类会造成阴影类代码来调用。
我想robolectric不知道你的类应该阴影;)
以下是如何告诉robolectric,你将跟随一些不能Android SDK中的类。
public class MyRobolectricTestRunner extends RobolectricTestRunner {
@Override
protected ClassLoader createRobolectricClassLoader(Setup setup, SdkConfig sdkConfig) {
return super.createRobolectricClassLoader(new ExtraShadows(setup), sdkConfig);
}
class ExtraShadows extends Setup {
private Setup setup;
public ExtraShadows(Setup setup) {
this.setup = setup;
}
public boolean shouldInstrument(ClassInfo classInfo) {
boolean shouldInstrument = setup.shouldInstrument(classInfo);
return shouldInstrument
|| classInfo.getName().equals(MyClass.class.getName());
}
}
}
对于robolectric 3 +:
创建一个扩展RobolectricGradleTestRunner自定义测试运行:
public class CustomRobolectricTestRunner extends RobolectricGradleTestRunner {
public CustomRobolectricTestRunner(Class<?> klass) throws InitializationError {
super(klass);
}
public InstrumentationConfiguration createClassLoaderConfig() {
InstrumentationConfiguration.Builder builder = InstrumentationConfiguration.newBuilder();
builder.addInstrumentedPackage("com.yourClassPackage");
return builder.build();
}
}