【问题标题】:Mocking a list which returns clone object in setter模拟在setter中返回克隆对象的列表
【发布时间】:2015-06-23 03:58:08
【问题描述】:

我正在尝试模拟一个列表

counted[binModel.getX() - 1][binModel.getY() - 1].add(activeModel);

addboolean,我正在尝试这个

Mockito.when(testee.getCounted()[binModel.getSelectionX() - 1]
    [binModel.getSelectionY() - 1].add(activeModel)).thenReturn(Mockito.anyBoolean());

这会在

上引发错误
public List<CountModel>[][] getCounted() {
    return counted.clone();
}

counted 在原类中声明为

private List<CountModel>[][] counted;

这是错误:

空指针和@mock private List[][] 计数; Mockito 无法模拟/监视以下内容:-最终类-匿名类-原始类型

【问题讨论】:

  • 它会抛出什么错误?
  • 空指针和 @mock private List[][] 计数; Mockito 无法模拟/监视以下内容:-最终类-匿名类-原始类型
  • 您能否发布更大范围的代码。在我看来,您不是在模拟一个模拟课程,而是一个真正的课程。

标签: junit mockito


【解决方案1】:

数组是java中的final类,所以不能mock。

您可能需要做的是自己用模拟填充数组,例如...

// Lose the @Mock annotation if that's how you set it up
private List<CountModel>[][] counted;

@Before
@SuppressWarnings("unchecked")
public void setup() {
    counted = new List[X_SIZE][Y_SIZE];

    for(int x = 0; x < X_SIZE; x++) {
        for(int y = 0; y < Y_SIZE; y++) {
            counted[x][y] = mock(List.class);
        }
    }
}

(不知道为什么你真的想模拟一个列表)

要解决“克隆”问题,您可以构建另一个模拟来表示克隆列表,或者只返回相同的列表...

@Before
@SuppressWarnings("unchecked")
public void setup() {
    counted = new List[X_SIZE][Y_SIZE];

    for(int x = 0; x < X_SIZE; x++) {
        for(int y = 0; y < Y_SIZE; y++) {
            counted[x][y] = mock(List.class);
            when(counted[x][y].clone()).thenReturn(counted[x][y]);
        }
    }
}

就像我说的那样,模拟列表可能不是最好的使用方法。也许创建一个包含模拟“CountModels”或其他内容的真实列表?

(您可能需要发布您的完整代码,以便让我对您正在尝试做的事情有更多的了解)

【讨论】:

  • +1,尤其是对于不模拟列表。那里没有什么可得到的;这纯粹是对模拟的过度使用。
  • 我想要的只是通过该步骤的测试。除了模拟它之外,可能还有另一个让测试通过它
猜你喜欢
  • 2017-08-24
  • 1970-01-01
  • 2019-03-25
  • 1970-01-01
  • 2018-03-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-02-10
相关资源
最近更新 更多