From 0439bed3147d35915987b97c67574d8f410d08ec Mon Sep 17 00:00:00 2001 From: algebro Date: Thu, 8 Aug 2024 14:33:29 -0400 Subject: [PATCH] add LAM tests --- .../megamek/server/GameManagerTest.java | 37 ++++++++++++++++++- 1 file changed, 35 insertions(+), 2 deletions(-) diff --git a/megamek/unittests/megamek/server/GameManagerTest.java b/megamek/unittests/megamek/server/GameManagerTest.java index 9c2b3cd506..6879dbc1a5 100644 --- a/megamek/unittests/megamek/server/GameManagerTest.java +++ b/megamek/unittests/megamek/server/GameManagerTest.java @@ -28,7 +28,7 @@ void setUp() { } @Test - void testAddControlWithAdvAtmosphericMergesIntoOneRoll() { + void testAddControlWithAdvAtmosphericMergesIntoOneRollAero() { AeroSpaceFighter aero = new AeroSpaceFighter(); game.addEntity(aero); Vector rolls = new Vector<>(); @@ -47,7 +47,7 @@ void testAddControlWithAdvAtmosphericMergesIntoOneRoll() { } @Test - void testAddControlWithAdvAtmosphericIncludesAllReasons() { + void testAddControlWithAdvAtmosphericIncludesAllReasonsAero() { AeroSpaceFighter aero = new AeroSpaceFighter(); game.addEntity(aero); Vector rolls = new Vector<>(); @@ -63,4 +63,37 @@ void testAddControlWithAdvAtmosphericIncludesAllReasons() { assertTrue(reasons.toString().contains("threshold")); assertTrue(reasons.toString().contains("highest damage threshold exceeded")); } + + @Test + void testAddControlWithAdvAtmosphericMergesIntoOneRollLAM() { + LandAirMech mech = new LandAirMech(LandAirMech.GYRO_STANDARD, LandAirMech.COCKPIT_STANDARD, LandAirMech.LAM_STANDARD); + game.addEntity(mech); + Vector rolls = new Vector<>(); + StringBuilder reasons = new StringBuilder(); + + game.addControlRoll(new PilotingRollData(mech.getId(), 0, "avionics hit")); + game.addControlRoll(new PilotingRollData(mech.getId(), 0, "threshold")); + game.addControlRoll(new PilotingRollData(mech.getId(), 0, "highest damage threshold exceeded")); + gameManager.addControlWithAdvAtmospheric(mech, rolls, reasons); + assertEquals(1, rolls.size()); + assertTrue(reasons.toString().contains("avionics hit")); + assertTrue(reasons.toString().contains("threshold")); + assertTrue(reasons.toString().contains("highest damage threshold exceeded")); + } + + @Test + void testAddControlWithAdvAtmosphericIncludesAllReasonsLAM() { + LandAirMech mech = new LandAirMech(LandAirMech.GYRO_STANDARD, LandAirMech.COCKPIT_STANDARD, LandAirMech.LAM_STANDARD); + game.addEntity(mech); + Vector rolls = new Vector<>(); + StringBuilder reasons = new StringBuilder(); + + game.addControlRoll(new PilotingRollData(mech.getId(), 0, "avionics hit")); + game.addControlRoll(new PilotingRollData(mech.getId(), 0, "threshold")); + game.addControlRoll(new PilotingRollData(mech.getId(), 0, "highest damage threshold exceeded")); + gameManager.addControlWithAdvAtmospheric(mech, rolls, reasons); + assertTrue(reasons.toString().contains("avionics hit")); + assertTrue(reasons.toString().contains("threshold")); + assertTrue(reasons.toString().contains("highest damage threshold exceeded")); + } } \ No newline at end of file