From 49f30529d9cd2ed62902079a45d4d3c1f45afbda Mon Sep 17 00:00:00 2001 From: Maƫl Gassmann Date: Fri, 11 Jun 2021 11:43:49 +0200 Subject: [+] Added JUnit tests (only testign valid expressions as of now) --- calculator-java/pom.xml | 14 +++ calculator-java/src/main/java/ch/bfh/Main.java | 2 - .../src/test/java/ExpressionParserTest.java | 115 +++++++++++++++++++++ 3 files changed, 129 insertions(+), 2 deletions(-) create mode 100644 calculator-java/src/test/java/ExpressionParserTest.java (limited to 'calculator-java') diff --git a/calculator-java/pom.xml b/calculator-java/pom.xml index 1edc3ba..d181b7d 100644 --- a/calculator-java/pom.xml +++ b/calculator-java/pom.xml @@ -7,6 +7,20 @@ ch.bfh calculator-java 1.0-SNAPSHOT + + + junit + junit + 4.13.1 + test + + + org.junit.jupiter + junit-jupiter-api + 5.7.0 + test + + 11 diff --git a/calculator-java/src/main/java/ch/bfh/Main.java b/calculator-java/src/main/java/ch/bfh/Main.java index 302f5ed..e57fc8a 100644 --- a/calculator-java/src/main/java/ch/bfh/Main.java +++ b/calculator-java/src/main/java/ch/bfh/Main.java @@ -1,8 +1,6 @@ package ch.bfh; import ch.bfh.parser.ExpressionParser; - -import java.util.Arrays; import java.util.Scanner; public class Main { diff --git a/calculator-java/src/test/java/ExpressionParserTest.java b/calculator-java/src/test/java/ExpressionParserTest.java new file mode 100644 index 0000000..8a9814c --- /dev/null +++ b/calculator-java/src/test/java/ExpressionParserTest.java @@ -0,0 +1,115 @@ +import ch.bfh.CalculatorLexer; +import ch.bfh.parser.ExpressionParser; +import org.junit.Test; +import static org.junit.Assert.assertEquals; + +public class ExpressionParserTest { + + // Only testing correct expressions first + @Test + public void emptyExpression() { + CalculatorLexer cl = new CalculatorLexer(); + cl.initLexer(""); + ExpressionParser ep = new ExpressionParser(cl); + assertEquals(0.0, ep.getValue(), 0.0); + } + + @Test + public void oneFactor() { + CalculatorLexer cl = new CalculatorLexer(); + cl.initLexer("10"); + ExpressionParser ep = new ExpressionParser(cl); + assertEquals(10.0, ep.getValue(), 0.0); + } + + @Test + public void oneParenthesisedFactor() { + CalculatorLexer cl = new CalculatorLexer(); + cl.initLexer("(10)"); + ExpressionParser ep = new ExpressionParser(cl); + assertEquals(10.0, ep.getValue(), 0.0); + } + + @Test + public void oneNegativeFactor() { + CalculatorLexer cl = new CalculatorLexer(); + cl.initLexer("-10"); + ExpressionParser ep = new ExpressionParser(cl); + assertEquals(-10.0, ep.getValue(), 0.0); + } + + @Test + public void oneNegativeParenthesisedFactor() { + CalculatorLexer cl = new CalculatorLexer(); + cl.initLexer("-(10)"); + ExpressionParser ep = new ExpressionParser(cl); + assertEquals(-10.0, ep.getValue(), 0.0); + } + + @Test + public void oneNegativeParenthesisedNegativeFactor() { + CalculatorLexer cl = new CalculatorLexer(); + cl.initLexer("-(-10)"); + ExpressionParser ep = new ExpressionParser(cl); + assertEquals(10.0, ep.getValue(), 0.0); + } + + @Test + public void twoFactorSum() { + CalculatorLexer cl = new CalculatorLexer(); + cl.initLexer("2+3"); + ExpressionParser ep = new ExpressionParser(cl); + assertEquals(5.0, ep.getValue(), 0.0); + } + + @Test + public void twoFactorSub() { + CalculatorLexer cl = new CalculatorLexer(); + cl.initLexer("2-3"); + ExpressionParser ep = new ExpressionParser(cl); + assertEquals(-1.0, ep.getValue(), 0.0); + } + + @Test + public void twoFactorSumWithSub() { + CalculatorLexer cl = new CalculatorLexer(); + cl.initLexer("2--3"); + ExpressionParser ep = new ExpressionParser(cl); + assertEquals(5.0, ep.getValue(), 0.0); + } + + @Test + public void twoFactorSumWithSubParenthesised() { + CalculatorLexer cl = new CalculatorLexer(); + cl.initLexer("2-(-3)"); + ExpressionParser ep = new ExpressionParser(cl); + assertEquals(5.0, ep.getValue(), 0.0); + } + + @Test + public void twoFactorMul() { + CalculatorLexer cl = new CalculatorLexer(); + cl.initLexer("2*3"); + ExpressionParser ep = new ExpressionParser(cl); + assertEquals(6.0, ep.getValue(), 0.0); + } + + @Test + public void twoFactorDiv() { + CalculatorLexer cl = new CalculatorLexer(); + cl.initLexer("11/4"); + ExpressionParser ep = new ExpressionParser(cl); + assertEquals(2.75, ep.getValue(), 0.0); + } + + @Test + public void completeArithmeticOperationWithPriorities() { + CalculatorLexer cl = new CalculatorLexer(); + cl.initLexer("(4+5)*3/4"); + ExpressionParser ep = new ExpressionParser(cl); + assertEquals(6.75, ep.getValue(), 0.0); + } + + //TODO - test error messages + +} -- cgit v1.2.3