0

这是我要测试的代码:

public class ValidateRegisterInputController {

    public boolean validateInputHandle(UserDataObject user1){
    ValidateInput validateinput = new ValidateInput();
    boolean check = true;

    if (!validateinput.validateUsername(user1.getUsername())) {
        check = false;
        BanUserGUI bangui = new BanUserGUI();
        bangui.displayBanGUI();
    }

    return check;
   }

但是,当我尝试运行测试时,它会启动“bangui.displayBanGUI()”方法并转到控制台请求输入,这意味着测试永远不会正确完成运行。这是我到目前为止的测试:

public class ValidateRegisterInputControllerTest {

    @Test
    public void testValidateRegisterInputControllervalidateInputHandleReturnsStringvalidWhenValidInputIsMade(){
    UserDataObject user1 = new UserDataObject(" ", "password1", "John", "Smith", 1);
    ValidateRegisterInputController controller = new ValidateRegisterInputController();

    assertTrue(controller.validateInputHandle(user1));

    }

}

所以基本上,如果我输入一个有效的用户名(例如,“John”),这个测试将通过,因为它不显示 GUI,只会返回检查,这是真的。

但是,如果我输入了一个无效的用户名,例如“”(只是空格),那么它应该返回 false,但它不会因为 GUI 启动。

我怎样才能停止它启动 GUI 并完成该方法。我在想 mockito 可能会派上用场,但我只学习了它的理论,并没有真正实现它!

提前致谢!

4

1 回答 1

2

您应该将 BanUserGUI 结构注入到您的代码中。使用 javax.inject.Provider。或者,您应该提取方法:

public class ValidateRegisterInputController {

    public boolean validateInputHandle(UserDataObject user1){
    ValidateInput validateinput = new ValidateInput();
    boolean check = true;

    if (!validateinput.validateUsername(user1.getUsername())) {
        check = false;
        BanUserGUI bangui = createBanUserGui();
        bangui.displayBanGUI();
    }

    return check;
   }

   BanUserGUI createBanUserGui()
   {
     return new BanUserGUI();
   }
}

在它之后,您可以简单地覆盖单元测试中的方法以返回模拟,或者使用 spy 模拟方法调用。

于 2013-08-03T12:32:09.810 回答