Skip to content
Open

HA01 #119

Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"java.jdt.ls.java.home": "C:\\Program Files\\Java\\jdk-22",
"java.compile.nullAnalysis.mode": "automatic",
"java.debug.settings.onBuildFailureProceed": true
}
54 changes: 47 additions & 7 deletions app/src/main/java/htw/berlin/prog2/ha1/Calculator.java
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
* https://www.online-calculator.com/ aufgerufen werden kann (ohne die Memory-Funktionen)
* und dessen Bildschirm bis zu zehn Ziffern plus einem Dezimaltrennzeichen darstellen kann.
* Enthält mit Absicht noch diverse Bugs oder unvollständige Funktionen.
* Nachricht Test.
*/
public class Calculator {

Expand All @@ -18,7 +19,9 @@ public class Calculator {
* @return den aktuellen Bildschirminhalt als String
*/
public String readScreen() {

return screen;

}

/**
Expand All @@ -29,11 +32,13 @@ public String readScreen() {
* @param digit Die Ziffer, deren Taste gedrückt wurde
*/
public void pressDigitKey(int digit) {

if(digit > 9 || digit < 0) throw new IllegalArgumentException();

if(screen.equals("0") || latestValue == Double.parseDouble(screen)) screen = "";

screen = screen + digit;

}

/**
Expand All @@ -45,9 +50,13 @@ public void pressDigitKey(int digit) {
* im Ursprungszustand ist.
*/
public void pressClearKey() {

screen = "0";

latestOperation = "";

latestValue = 0.0;

}

/**
Expand All @@ -60,8 +69,11 @@ public void pressClearKey() {
* @param operation "+" für Addition, "-" für Substraktion, "x" für Multiplikation, "/" für Division
*/
public void pressBinaryOperationKey(String operation) {

latestValue = Double.parseDouble(screen);

latestOperation = operation;

}

/**
Expand All @@ -72,16 +84,24 @@ public void pressBinaryOperationKey(String operation) {
* @param operation "√" für Quadratwurzel, "%" für Prozent, "1/x" für Inversion
*/
public void pressUnaryOperationKey(String operation) {

latestValue = Double.parseDouble(screen);

latestOperation = operation;

var result = switch(operation) {

case "√" -> Math.sqrt(Double.parseDouble(screen));
case "%" -> Double.parseDouble(screen) / 100;
case "1/x" -> 1 / Double.parseDouble(screen);
default -> throw new IllegalArgumentException();

};

screen = Double.toString(result);

if(screen.equals("NaN")) screen = "Error";

if(screen.contains(".") && screen.length() > 11) screen = screen.substring(0, 10);

}
Expand All @@ -94,7 +114,9 @@ public void pressUnaryOperationKey(String operation) {
* Beim zweimaligem Drücken, oder wenn bereits ein Trennzeichen angezeigt wird, passiert nichts.
*/
public void pressDotKey() {

if(!screen.contains(".")) screen = screen + ".";

}

/**
Expand All @@ -105,7 +127,9 @@ public void pressDotKey() {
* entfernt und der Inhalt fortan als positiv interpretiert.
*/
public void pressNegativeKey() {

screen = screen.startsWith("-") ? screen.substring(1) : "-" + screen;

}

/**
Expand All @@ -118,16 +142,32 @@ public void pressNegativeKey() {
* und das Ergebnis direkt angezeigt.
*/
public void pressEqualsKey() {
var result = switch(latestOperation) {
case "+" -> latestValue + Double.parseDouble(screen);
case "-" -> latestValue - Double.parseDouble(screen);
case "x" -> latestValue * Double.parseDouble(screen);
case "/" -> latestValue / Double.parseDouble(screen);

if (latestOperation.isEmpty()) return;

double newValue = Double.parseDouble(screen);

double result = switch(latestOperation) {

case "+" -> latestValue + newValue;
case "-" -> latestValue - newValue;
case "x" -> latestValue * newValue;
case "/" -> latestValue / newValue;

default -> throw new IllegalArgumentException();

};

latestValue = newValue;

screen = Double.toString(result);

if(screen.equals("Infinity")) screen = "Error";

if(screen.endsWith(".0")) screen = screen.substring(0,screen.length()-2);

if(screen.contains(".") && screen.length() > 11) screen = screen.substring(0, 10);
}
}

}

}
56 changes: 55 additions & 1 deletion app/src/test/java/htw/berlin/prog2/ha1/CalculatorTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,60 @@ void testMultipleDecimalDots() {
}


//TODO hier weitere Tests erstellen
//Teilaufgabe 01 - zusätzlicher Test
@Test
@DisplayName("should display result when dividing a positive multi-digit number with another single-digit number")
void testDivisionByDecimal() {
Calculator calc = new Calculator();

calc.pressDigitKey(4);
calc.pressDigitKey(5);
calc.pressBinaryOperationKey("/");
calc.pressDigitKey(9);
calc.pressEqualsKey();

String expected = "5";
String actual = calc.readScreen();

assertEquals(expected, actual);
}

//Teilaufgabe 02

@Test
@DisplayName("should repeat last operation on continuous equals presses")
void testRepeatLastOperation() {
Calculator calc = new Calculator();

calc.pressDigitKey(5);
calc.pressBinaryOperationKey("+");
calc.pressDigitKey(3);
calc.pressEqualsKey();
calc.pressEqualsKey();

String expected = "11";
String actual = calc.readScreen();

assertEquals(expected, actual);
}

@Test
@DisplayName("should repeat last operation on continuous equals presses")
void testNewNumberAfterResult() {
Calculator calc = new Calculator();

calc.pressDigitKey(5);
calc.pressBinaryOperationKey("+");
calc.pressDigitKey(3);
calc.pressEqualsKey();
calc.pressDigitKey(3);
calc.pressEqualsKey();

String expected = "6";
String actual = calc.readScreen();

assertEquals(expected, actual);
}

}