Para probar su código, debe crear un contenedor para las funciones de entrada / salida del sistema. Puede hacer esto usando la inyección de dependencia, dándonos una clase que puede solicitar nuevos enteros:
public static class IntegerAsker {
private final Scanner scanner;
private final PrintStream out;
public IntegerAsker(InputStream in, PrintStream out) {
scanner = new Scanner(in);
this.out = out;
}
public int ask(String message) {
out.println(message);
return scanner.nextInt();
}
}
Luego puede crear pruebas para su función, usando un marco simulado (yo uso Mockito):
@Test
public void getsIntegerWhenWithinBoundsOfOneToTen() throws Exception {
IntegerAsker asker = mock(IntegerAsker.class);
when(asker.ask(anyString())).thenReturn(3);
assertEquals(getBoundIntegerFromUser(asker), 3);
}
@Test
public void asksForNewIntegerWhenOutsideBoundsOfOneToTen() throws Exception {
IntegerAsker asker = mock(IntegerAsker.class);
when(asker.ask("Give a number between 1 and 10")).thenReturn(99);
when(asker.ask("Wrong number, try again.")).thenReturn(3);
getBoundIntegerFromUser(asker);
verify(asker).ask("Wrong number, try again.");
}
Luego escribe tu función que pasa las pruebas. La función es mucho más limpia, ya que puede eliminar la duplicación de enteros preguntando / obteniendo y las llamadas al sistema reales están encapsuladas.
public static void main(String[] args) {
getBoundIntegerFromUser(new IntegerAsker(System.in, System.out));
}
public static int getBoundIntegerFromUser(IntegerAsker asker) {
int input = asker.ask("Give a number between 1 and 10");
while (input < 1 || input > 10)
input = asker.ask("Wrong number, try again.");
return input;
}
Esto puede parecer excesivo para su pequeño ejemplo, pero si está construyendo una aplicación más grande, el desarrollo de este tipo puede resultar bastante rápido.