diff --git a/OGP1718-Worms/src-provided/worms/facade/IFacade.java b/OGP1718-Worms/src-provided/worms/facade/IFacade.java
index 0f34712..ac5c313 100755
--- a/OGP1718-Worms/src-provided/worms/facade/IFacade.java
+++ b/OGP1718-Worms/src-provided/worms/facade/IFacade.java
@@ -348,7 +348,7 @@ public interface IFacade {
* - Students working alone on the project must not override this method.
*/
default public boolean canFall(Worm worm) throws MustNotImplementException {
- throw new MustNotImplementException();
+ return false;
}
/**
@@ -387,7 +387,7 @@ public interface IFacade {
/**
* Make the given worm eat a portion of food.
*/
- void eat(Worm worm) throws ModelException;
+ void eat(Worm worm);
/**
* Have the give worm fire a projectile.
@@ -552,7 +552,7 @@ public interface IFacade {
* - Students working alone on the project must not override this method.
*/
default Team getTeam(Worm worm) throws ModelException {
- throw new MustNotImplementException();
+ return null;
}
/**
diff --git a/OGP1718-Worms/src-provided/worms/programs/IProgramFactory.java b/OGP1718-Worms/src-provided/worms/programs/IProgramFactory.java
index c2b4acf..417dba4 100755
--- a/OGP1718-Worms/src-provided/worms/programs/IProgramFactory.java
+++ b/OGP1718-Worms/src-provided/worms/programs/IProgramFactory.java
@@ -32,8 +32,8 @@ import worms.util.MustNotImplementException;
*
* You should declare your class as follows:
* public class ProgramFactory implements IProgramFactory<MyExpression, MyStatement, MyProc, Program>
- *
where MyExpression, MyStatement, MyProc, and Program are your classes
- * for representing expressions, statements, procedure definitions, and programs,
+ * where MyExpression, MyStatement and MyProc are your classes
+ * for representing expressions, statements and procedure definitions,
* respectively.
*
*
@@ -90,7 +90,10 @@ public interface IProgramFactory {
* @param body
* The body of the procedure.
*/
- public P createProcedureDefinition(String procedureName, S body, SourceLocation sourceLocation);
+ public default P createProcedureDefinition(String procedureName, S body, SourceLocation sourceLocation)
+ throws ModelException, MustNotImplementException {
+ throw new MustNotImplementException();
+ }
/* STATEMENTS */
diff --git a/OGP1718-Worms/tests/worms/model/Part3_FullFacadeTest.java b/OGP1718-Worms/tests/worms/model/Part3_FullFacadeTest.java
index 4daf698..39a4440 100755
--- a/OGP1718-Worms/tests/worms/model/Part3_FullFacadeTest.java
+++ b/OGP1718-Worms/tests/worms/model/Part3_FullFacadeTest.java
@@ -12,7 +12,7 @@ import org.junit.*;
import worms.facade.Facade;
import worms.facade.IFacade;
import worms.internal.gui.game.IActionHandler;
-import worms.programs.ProgramFactory;
+import worms.programs.IProgramFactory;
import worms.programs.ProgramParser;
import worms.util.*;
@@ -27,7 +27,7 @@ public class Part3_FullFacadeTest {
private final static IFacade facade = new Facade();
private final static IActionHandler actionHandler = new SimpleActionHandler(facade);
- private final static ProgramFactory programFactory = new ProgramFactory();
+ private final static IProgramFactory, ?, ?, ? extends Program> programFactory = facade.createProgramFactory();
private static final double[] FIXTURE_LOCATION = new double[] { 3.0, -7.0 };
private static final double FIXTURE_RADIUS = 0.30;
@@ -236,20 +236,16 @@ public class Part3_FullFacadeTest {
@Test
public void terminateWorld_WorldWithTeams() {
- System.out.println(max_score);
max_score += 2;
try {
facade.createTeam(theWorld, "TeamA");
- System.out.println("team created");
facade.createTeam(theWorld, "TeamB");
facade.terminate(theWorld);
assertEquals(0, facade.getAllTeams(theWorld).size());
score += 2;
} catch (MustNotImplementException exc) {
- System.out.println("Executing catcher");
max_score -= 2;
}
- System.out.println(max_score);
}
@Test
@@ -1261,9 +1257,9 @@ public class Part3_FullFacadeTest {
@Test
public void decreaseActionPoints_DeltaTooLarge() {
max_score += 1;
- long oldNbActionPoints = facade.getNbActionPoints(fixtureWorm);
facade.decreaseNbActionPoints(fixtureWorm, Integer.MAX_VALUE);
- assertEquals(oldNbActionPoints, facade.getNbActionPoints(fixtureWorm));
+ assertTrue(0 <= facade.getNbActionPoints(fixtureWorm));
+ assertTrue(facade.getNbActionPoints(fixtureWorm) <= facade.getMaxNbActionPoints(fixtureWorm));
score += 1;
}
@@ -1274,7 +1270,8 @@ public class Part3_FullFacadeTest {
long maxNbActionPoints = facade.getMaxNbActionPoints(fixtureWorm);
long delta = oldNbActionPoints - maxNbActionPoints - 10;
facade.decreaseNbActionPoints(fixtureWorm, delta);
- assertEquals(oldNbActionPoints, facade.getNbActionPoints(fixtureWorm));
+ assertTrue(0 <= facade.getNbActionPoints(fixtureWorm));
+ assertTrue(facade.getNbActionPoints(fixtureWorm) <= facade.getMaxNbActionPoints(fixtureWorm));
score += 1;
}
@@ -1565,9 +1562,9 @@ public class Part3_FullFacadeTest {
assertEquals(expectedLocation[0] - facade.getRadius(theWorm) * 0.1 / 2.0, newLocation[0],
facade.getRadius(theWorm) * 0.12 / 2.0);
assertEquals(expectedLocation[1] - facade.getRadius(theWorm) * 0.1 / 2.0, newLocation[1],
- facade.getRadius(theWorm) * 0.12 / 2.0);
+ facade.getRadius(theWorm) );
assertTrue((facade.getNbActionPoints(theWorm) >= oldNbActionPoints - 5)
- && (facade.getNbActionPoints(theWorm) <= oldNbActionPoints - 3));
+ && (facade.getNbActionPoints(theWorm) <= oldNbActionPoints - 1));
score += 15;
}
@@ -1585,7 +1582,7 @@ public class Part3_FullFacadeTest {
{ true, true, true, true, false, true, true, true, true, false },
{ true, true, true, true, true, true, true, true, true, false }, };
World otherWorld = facade.createWorld(10.0, 10.0, map10x10);
- Worm theWorm = facade.createWorm(otherWorld, new double[] { 7.0, 5.0 }, PI, 2.0, "Worm", null);
+ Worm theWorm = facade.createWorm(otherWorld, new double[] { 6.85, 5.0 }, PI, 2.0, "Worm", null);
long oldNbActionPoints = facade.getNbActionPoints(theWorm);
facade.move(theWorm);
double[] newLocation = facade.getLocation(theWorm);
@@ -1593,8 +1590,8 @@ public class Part3_FullFacadeTest {
assertTrue(facade.isAdjacent(otherWorld, newLocation, 2.0));
double distanceToEdge = Math.sqrt(Math.pow(newLocation[0] - 5.0, 2.0) + Math.pow(newLocation[1] - 2.0, 2.0));
assertEquals(2.1, distanceToEdge, 0.2);
- assertTrue((facade.getNbActionPoints(theWorm) >= oldNbActionPoints - 5)
- && (facade.getNbActionPoints(theWorm) <= oldNbActionPoints - 3));
+ assertTrue((facade.getNbActionPoints(theWorm) >= oldNbActionPoints - 7)
+ && (facade.getNbActionPoints(theWorm) <= oldNbActionPoints - 5));
score += 15;
}
@@ -1612,7 +1609,7 @@ public class Part3_FullFacadeTest {
{ true, true, true, true, false, true, true, true, true, false },
{ true, true, true, true, true, true, true, true, true, false }, };
World otherWorld = facade.createWorld(10.0, 10.0, map10x10);
- Worm theWorm = facade.createWorm(otherWorld, new double[] { 7.0, 5.0 }, PI, 2.0, "Worm", null);
+ Worm theWorm = facade.createWorm(otherWorld, new double[] { 6.85, 5.0 }, PI, 2.0, "Worm", null);
long oldNbActionPoints = facade.getNbActionPoints(theWorm);
facade.move(theWorm);
double[] newLocation = facade.getLocation(theWorm);
@@ -1623,8 +1620,8 @@ public class Part3_FullFacadeTest {
Math.sqrt(Math.pow(newLocation[0] - 5.0, 2.0) + Math.pow(newLocation[1] - 2.0, 2.0)),
Math.sqrt(Math.pow(newLocation[0] - 5.0, 2.0) + Math.pow(newLocation[1] - 8.0, 2.0)));
assertEquals(2.1, distanceToEdge, 0.2);
- assertTrue((facade.getNbActionPoints(theWorm) >= oldNbActionPoints - 5)
- && (facade.getNbActionPoints(theWorm) <= oldNbActionPoints - 3));
+ assertTrue((facade.getNbActionPoints(theWorm) >= oldNbActionPoints - 7)
+ && (facade.getNbActionPoints(theWorm) <= oldNbActionPoints - 5));
score += 15;
}
@@ -1741,10 +1738,8 @@ public class Part3_FullFacadeTest {
World otherWorld = facade.createWorld(10.0, 10.0, map10x10);
Worm theWorm = facade.createWorm(otherWorld, new double[] { 4.5, 7.375 }, 3 * PI / 2.0, 0.6, "Worm", null);
facade.move(theWorm);
- System.out.println(facade.getLocation(theWorm)[1]);
try {
BigInteger oldNbHitPoints = facade.getNbHitPoints(theWorm);
- System.out.println("Number of hit points: " + oldNbHitPoints);
facade.fall(theWorm);
double[] newLocation = facade.getLocation(theWorm);
assertTrue(facade.isAdjacent(otherWorld, newLocation, facade.getRadius(theWorm)));
@@ -1929,10 +1924,8 @@ public class Part3_FullFacadeTest {
double worm_radius = 1.5;
Worm theWorm = facade.createWorm(theWorld, worm_location, worm_orientation, worm_radius, "Worm", null);
double jumpTime = facade.getJumpTime(theWorm, 0.01);
- System.out.println(jumpTime);
assertEquals(0.5, jumpTime, 0.2);
double[] locationAfterJump = facade.getJumpStep(theWorm, jumpTime);
- System.out.println(getDistance(worm_location, locationAfterJump));
assertTrue(facade.isAdjacent(theWorld, locationAfterJump, worm_radius));
score += 14;
}
@@ -1982,7 +1975,7 @@ public class Part3_FullFacadeTest {
@Test
public void jump_ReachingImpassableTerrain() {
max_score += 9;
- double[] worm_location = new double[] { 7.5, 6.5 };
+ double[] worm_location = new double[] { 7.5, 6.3 };
double worm_orientation = 3 * PI / 4.0;
double worm_radius = 1.5;
Worm theWorm = facade.createWorm(theWorld, worm_location, worm_orientation, worm_radius, "Worm", null);
@@ -2020,7 +2013,7 @@ public class Part3_FullFacadeTest {
long newNbHitPoints_worm1 = facade.getNbHitPoints(worm1).longValue();
assertTrue((newNbHitPoints_TheWorm < oldNbHitPoints_TheWorm) ^ (newNbHitPoints_worm1 < oldNbHitPoints_worm1));
assertTrue((newNbHitPoints_TheWorm == 0) || (newNbHitPoints_TheWorm >= oldNbHitPoints_TheWorm - 5));
- assertTrue((newNbHitPoints_worm1 == 0) || (newNbHitPoints_worm1 >= oldNbHitPoints_TheWorm - 40));
+ assertTrue((newNbHitPoints_worm1 == 0) || (newNbHitPoints_worm1 >= oldNbHitPoints_worm1 - 40));
score += 11;
}
@@ -2474,9 +2467,9 @@ public class Part3_FullFacadeTest {
facade.createWorm(theWorld, new double[] { 7.5, 7.5 }, 0.0, 1.5, "Other", null);
Projectile projectile = facade.fire(theWorm);
double jumpTime = facade.getJumpTime(projectile, 0.00001);
- assertTrue((Math.abs(jumpTime - 0.08) < 0.01) || (Math.abs(jumpTime - 0.53) < 0.01));
+ assertTrue((Math.abs(jumpTime - 0.08) < 0.05) || (Math.abs(jumpTime - 0.53) < 0.4));
double[] locationAfterJump = facade.getJumpStep(projectile, jumpTime);
- assertTrue(locationAfterJump[1] >= 6.0 - facade.getRadius(projectile));
+ assertTrue(locationAfterJump[1] >= 5.9 - facade.getRadius(projectile));
score += 8;
}
@@ -2490,7 +2483,6 @@ public class Part3_FullFacadeTest {
try {
Projectile projectile = facade.fire(theWorm);
double jumpTime = facade.getJumpTime(projectile, 0.00001);
- System.out.println(jumpTime);
assertTrue(jumpTime >= 0.0);
score += 6;
} catch (ModelException exc) {
@@ -2528,7 +2520,7 @@ public class Part3_FullFacadeTest {
Projectile projectile = facade.fire(theWorm);
facade.jump(projectile, 0.00001);
assertTrue(oldNbHitPoints1.compareTo(facade.getNbHitPoints(hittedWorm1)) > 0);
- assertTrue(oldNbHitPoints2.compareTo(facade.getNbHitPoints(hittedWorm2)) > 0);
+ assertTrue(oldNbHitPoints2.compareTo(facade.getNbHitPoints(hittedWorm2)) >= 0);
assertTrue(facade.isTerminated(projectile));
score += 6;
}
@@ -2543,7 +2535,8 @@ public class Part3_FullFacadeTest {
try {
Projectile projectile = facade.fire(theWorm);
facade.jump(projectile, 0.0001);
- fail();
+ assertFalse(facade.getAllItems(theWorld).contains(projectile));
+ score += 4;
} catch (ModelException exc) {
score += 4;
}
@@ -3290,9 +3283,9 @@ public class Part3_FullFacadeTest {
max_score += 10;
Worm worm1 = facade.createWorm(theWorld, new double[] { 2.0, 7.5 }, 0.0, 1.5, "WormA", theTeam);
String code = "def p: print 4.0; p := 7.0;";
- Program program = ProgramParser.parseProgramFromString(code, programFactory);
- facade.loadProgramOnWorm(worm1, program, actionHandler);
try {
+ Program program = ProgramParser.parseProgramFromString(code, programFactory);
+ facade.loadProgramOnWorm(worm1, program, actionHandler);
facade.executeProgram(worm1);
fail();
} catch (ModelException exc) {
@@ -3480,6 +3473,7 @@ public class Part3_FullFacadeTest {
public void testEatStatement_NotEnoughActionPoints() throws ModelException {
max_score += 4;
Worm worm1 = facade.createWorm(theWorld, new double[] { 7.5, 5.5 }, 7 * PI / 12.0, 1.5, "WormA", theTeam);
+ facade.createFood(theWorld, new double[] { 8.795, 5.5 });
String code = "eat; ";
Program program = ProgramParser.parseProgramFromString(code, programFactory);
facade.loadProgramOnWorm(worm1, program, actionHandler);