使用spock进行单元测试-测试私有字段上的交互

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

我想使用Spock测试我的addMCU类的removeMCUMCUModel方法。但是,我对如何解决这个问题感到有点困惑。

public class MCUModel {

    private static int counter = 1;

    private final ObjectProperty<MCU> selectedMCU;
    private final ObservableList<MCU> mcuList;

    public MCUModel() {
        selectedMCU = new SimpleObjectProperty<>(null);
        mcuList = FXCollections.observableArrayList();
    }

    public ObjectProperty<MCU> selectedMCUProperty() {
        return selectedMCU;
    }

    public void setSelectedMCU(MCU mcu) {
        selectedMCU.set(mcu);
    }

    public ObservableList<MCU> getMCUList() {
        return mcuList;
    }

    public void addMCU() {
        MCU mcu = new MCU();
        mcu.setName("MCU" + counter++);
        mcuList.add(mcu);
        selectedMCU.set(mcu);
    }

    public void removeMCU() {
        if (selectedMCU.get() == null) return;

        int index = mcuList.indexOf(selectedMCU.get());
        mcuList.remove(index);

        if (mcuList.size() == 0)
            selectedMCU.set(null);
        else if (mcuList.size() > index)
            selectedMCU.set(mcuList.get(index));
        else
            selectedMCU.set(mcuList.get(--index));
    }

}

在这里的其他示例中,建议按照以下方式更改构造函数:

public MCUModel(ObjectProperty<MCU> selectedMCU, ObservableList<MCU> mcuList) {
        this.selectedMCU = selectedMCU;
        this.mcuList = mcuList;
    }

这将允许我模拟字段以测试是否调用了方法。但是,我不确定在这种情况下这是否是正确的方法。

我想,在使用addMCU方法的情况下,我想测试是否创建了新实例,并且mcuList.add(mcu)selectedMCU.set()都被调用并传递了该实例。

java unit-testing testing groovy spock
1个回答
0
投票

您的直觉是正确的,您无需模拟MCUModel的字段即可对其进行测试。这样做会将您的测试与类的私有数据的实现细节耦合在一起。测试不需要知道MCUModel完全有任何字段或依赖性。并且使测试对依赖项不了解,可以让您自由地在将来更改它们(即重构)而不会破坏测试。

我会通过吸气剂测试装夹工。您可以将其分解为两个以上的测试,或者使用循环。但是我们的想法是使用至少两种状态的模型测试每种方法:空和填充。

def "AddMCU"() {
    given: "Empty model"
        MCUModel model = new MCUModel()
    when: "Add to empty model"
        model.addMCU()
    then: "Model is populated"
        model.getMCUList().size() == 1
        model.selectedMCUProperty() == model.getMCUList().first()
    when: "Add to populated model"
        model.addMCU()
    then: "Model size increments"
        model.getMCUList().size() == 2
        model.selectedMCUProperty() == model.getMCUList().last()
}

def "RemoveMCU"() {
    given: "Populated model"
        MCUModel model = new MCUModel()
        model.addMCU()
    when: "Remove from populated model"
        model.removeMCU()
    then: "Model is empty"
        model.getMCUList().isEmpty()
        model.selectedMCUProperty() == null
    when: "Remove from empty model"
        model.removeMCU()
    then: "Model remains empty"
        model.getMCUList().isEmpty()
        model.selectedMCUProperty() == null
}
© www.soinside.com 2019 - 2024. All rights reserved.