改变mockito间谍的领域

问题描述 投票:0回答:1

假设我有课

class JustAClass() {
  Stirng justAField = "nothing";
}

现在我正在测试这个类,并将其放入模拟中

JustAClass realClass = newJustACLass();
JustAClass spyClass = Mockito.spy(realClass);

spyClass.justAField = "something"

问题是:

realClass.justAField
现在等于什么?

编辑:回应@fge 这并没有失败。

    CSVExport spyClass = Mockito.spy(testClass);
    FileOutputStream wFile = Mockito.mock(FileOutputStream.class);

    spyClass.wFile = wFile;

    Mockito.doThrow(IOException.class).when(spyClass).createBlankWorkbook();
    spyClass.export(testEnabledFields);
    Mockito.doThrow(IOException.class).when(wFile).close();
    spyClass.export(testEnabledFields);

那么testClass中的wFile现在是mock的还是原来的?

java mockito spy
1个回答
1
投票

从API文档中提取此内容http://docs.mockito.googlecode.com/hg-history/be6d53f62790ac7c9cf07c32485343ce94e1b563/1.9.5/org/mockito/Spy.html

Mockito 不会将调用委托给传递的真实实例,而是实际上创建它的副本。因此,如果您保留真实实例并与其交互,则不要指望间谍能够意识到这些交互及其对真实实例状态的影响。推论是,当在间谍上调用未存根的方法而不是在真实实例上调用时,您不会看到对真实实例有任何影响

© www.soinside.com 2019 - 2024. All rights reserved.