我的目标是使用Mockito模拟Build.Version.SDK_INT。已经尝试过:
final Build.VERSION buildVersion = Mockito.mock(Build.VERSION.class);
doReturn(buildVersion.getClass()).when(buildVersion).getClass();
doReturn(16).when(buildVersion.SDK_INT);
问题是:当mock需要方法时,.SDK_INT不是方法。
答案 0 :(得分:5)
到目前为止,与此类似的其他问题看起来你必须使用反射。
Stub value of Build.VERSION.SDK_INT in Local Unit Test
How to mock a static final variable using JUnit, EasyMock or PowerMock
static void setFinalStatic(Field field, Object newValue) throws Exception {
field.setAccessible(true);
Field modifiersField = Field.class.getDeclaredField("modifiers");
modifiersField.setAccessible(true);
modifiersField.setInt(field, field.getModifiers() & ~Modifier.FINAL);
field.set(null, newValue);
}
...然后在这种情况下像这样使用它......
setFinalStatic(Build.VERSION.class.getField("SDK_INT"), 16);
另一种方法是创建一个类,该类在稍后可以模拟的方法中访问/包装该字段
public interface BuildVersionAccessor {
int getSDK_INT();
}
然后嘲笑那个类/接口
BuildVersionAccessor buildVersion = mock(BuildVersionAccessor.class);
when(buildVersion.getSDK_INT()).thenReturn(16);
答案 1 :(得分:5)
这对我来说在使用PowerMockito时很有用。
Whitebox.setInternalState(Build.VERSION.class, "SDK_INT", 16);
别忘了输入
@PrepareForTest({Build.VERSION.class})
答案 2 :(得分:0)
对于java.lang.ExceptionInInitializerError,使用'SuppressStaticInitializationFor'禁止类中的任何静态块。可用示例如下:
@SuppressStaticInitializationFor({ "android.os.Build$VERSION", "SampleClassName" )}
请注意,内部类必须使用$而不是Dot。