diff --git a/src/main/java/tdd/setup/Calculator.java b/src/main/java/tdd/setup/Calculator.java index 171f6d6..b55249a 100644 --- a/src/main/java/tdd/setup/Calculator.java +++ b/src/main/java/tdd/setup/Calculator.java @@ -3,7 +3,7 @@ // behaviour inspired by https://www.online-calculator.com/ public class Calculator { - private String screen = "0"; + private String screen = ""; private double latestValue; @@ -12,25 +12,31 @@ public class Calculator { public String readScreen() { return screen; } + public void pressDigitKey(int digit) { if(digit > 9 || digit < 0) throw new IllegalArgumentException(); - if(latestOperation.isEmpty()) { - screen = screen + digit; + screen += digit; + } else if(screen.contains(".")) { + screen += Integer.toString(digit); + System.out.println(latestValue); } else { - latestValue = Double.parseDouble(screen); screen = Integer.toString(digit); + System.out.println(latestValue); } } public void pressClearKey() { screen = "0"; - latestOperation = ""; + latestOperation = "0"; latestValue = 0.0; + } public void pressOperationKey(String operation) { latestOperation = operation; + latestValue = Double.parseDouble(screen); + screen = ""; } public void pressDotKey() { @@ -42,6 +48,8 @@ public void pressNegative() { } public void pressEquals() { + System.out.println(screen); + System.out.println(latestValue +", screen: " +screen + "operation: " + (latestValue * Double.parseDouble(screen))); var result = switch(latestOperation) { case "+" -> latestValue + Double.parseDouble(screen); case "-" -> latestValue - Double.parseDouble(screen); @@ -49,7 +57,10 @@ public void pressEquals() { case "/" -> latestValue / Double.parseDouble(screen); default -> throw new IllegalArgumentException(); }; - screen = Double.toString(result); + + screen = Double.toString(Math.round( 100.0 * result) / 100.0); if(screen.endsWith(".0")) screen = screen.substring(0,screen.length()-2); + latestOperation = ""; + } } diff --git a/src/test/java/tdd/setup/CalculatorTest.java b/src/test/java/tdd/setup/CalculatorTest.java index 3bf16e9..7028d75 100644 --- a/src/test/java/tdd/setup/CalculatorTest.java +++ b/src/test/java/tdd/setup/CalculatorTest.java @@ -6,6 +6,7 @@ @DisplayName("Retro calculator") class CalculatorTest { + @Test @DisplayName("should display result after adding two positive numbers") void calculatorCanDoTwoPlusTwo() { @@ -16,4 +17,41 @@ void calculatorCanDoTwoPlusTwo() { calc.pressEquals(); assertEquals("4", calc.readScreen()); } + + @Test + @DisplayName("should display result after subtracting two positiv digits" ) + void calculatorCanDoTwoMinusTwo() { + Calculator calc = new Calculator(); + calc.pressDigitKey(2); + calc.pressOperationKey("-"); + calc.pressDigitKey(2); + calc.pressEquals(); + assertEquals("0", calc.readScreen()); + } + + @Test + @DisplayName("should display a double digit") + void calculatorCanDisplaySomething() { + Calculator calc = new Calculator(); + calc.pressDigitKey(3); + assertEquals("3", calc.readScreen()); + calc.pressClearKey(); + assertEquals("0", calc.readScreen()); + } + + @Test + @DisplayName("should display a double digit") + void calculatorCanDisplayDigit() { + Calculator calc = new Calculator(); + calc.pressDigitKey(3); + calc.pressDotKey(); + calc.pressDigitKey(3); + assertEquals("3.3", calc.readScreen()); + calc.pressOperationKey("x"); + calc.pressDigitKey(3); + calc.pressDotKey(); + calc.pressDigitKey(3); + calc.pressEquals(); + assertEquals("10.89", calc.readScreen()); + } }