1

我正在使用 Robolectric 3,我正在尝试像这样隐藏自定义类:

public class Yakir {

    public int foo() {
        return 1;
    }


}

@Implements(Yakir.class)
public class TestYakir {

    @Implementation
    public int foo() {
        return 2;
    }


}

而且我已经阅读了 Robolectric 阴影 SDK 类和自定义类的其他答案和帖子,我需要做一些特别的事情像这样:

公共类 RoboServiceRunner 扩展 RobolectricGradleTestRunner {

public RoboServiceRunner(Class<?> klass) throws InitializationError {
    super(klass);
}


@Override
public Config getConfig(Method method) {
    Config config = super.getConfig(method);
    config.shadows();
    return config;
}


@Override
protected ShadowMap createShadowMap(){
    ShadowMap shadowMap = super.createShadowMap();
    shadowMap = shadowMap.newBuilder().addShadowClass(ServiceTest.TestYakir.class).build();
    return shadowMap;
}


}

因此,您在这里看到的是将新类添加到 shadowMap 的代码。我也知道是否有Shadows课程,但我找不到如何处理它。

所以这个测试的输出:

@RunWith(RoboServiceRunner.class)
@Config(constants = BuildConfig.class, shadows =   {ServiceTest.TestYakir.class})

 public class ServiceTest {

@Test
@Config(constants = BuildConfig.class, shadows = {ServiceTest.TestYakir.class})
public void testService() {

    assertEquals(2, new Yakir().foo());

}

是:

junit.framework.AssertionFailedError:预期:2 实际:1

谢谢!

4

1 回答 1

2

因此,在网络上进行了更多挖掘之后,我找到了一个对我有用的简单解决方案。

您需要做的就是覆盖扩展类中的方法

RobolectricGradleTestRunner

方法是:

@Override
public InstrumentationConfiguration createClassLoaderConfig() {
    InstrumentationConfiguration.Builder builder = InstrumentationConfiguration.newBuilder();
    builder.addInstrumentedClass(YourCustomShadowClass.class.getName());
    return builder.build();    }

就是这样!测试以优异的成绩通过:)

于 2015-12-21T11:33:21.937 回答