|
|
|
|
@ -19,18 +19,18 @@ public class BoatInRaceTest {
|
|
|
|
|
@Test
|
|
|
|
|
public void calculateDueNorthAzimuthReturns0() {
|
|
|
|
|
|
|
|
|
|
CompoundMark startCompoundMark = new CompoundMark(ORIGIN_COORDS);
|
|
|
|
|
CompoundMark endCompoundMark = new CompoundMark(new GPSCoordinate(50, 0));
|
|
|
|
|
Leg start = new Leg("Start", startCompoundMark, endCompoundMark, 0);
|
|
|
|
|
Marker startMarker = new Marker(ORIGIN_COORDS);
|
|
|
|
|
Marker endMarker = new Marker(new GPSCoordinate(50, 0));
|
|
|
|
|
Leg start = new Leg("Start", startMarker, endMarker, 0);
|
|
|
|
|
TEST_BOAT.setCurrentLeg(start);
|
|
|
|
|
assertEquals(TEST_BOAT.calculateAzimuth(), 0, 1e-8);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void calculateDueSouthAzimuthReturns180() {
|
|
|
|
|
CompoundMark startCompoundMark = new CompoundMark(ORIGIN_COORDS);
|
|
|
|
|
CompoundMark endCompoundMark = new CompoundMark(new GPSCoordinate(-50, 0));
|
|
|
|
|
Leg start = new Leg("Start", startCompoundMark, endCompoundMark, 0);
|
|
|
|
|
Marker startMarker = new Marker(ORIGIN_COORDS);
|
|
|
|
|
Marker endMarker = new Marker(new GPSCoordinate(-50, 0));
|
|
|
|
|
Leg start = new Leg("Start", startMarker, endMarker, 0);
|
|
|
|
|
TEST_BOAT.setCurrentLeg(start);
|
|
|
|
|
assertEquals(TEST_BOAT.calculateAzimuth(), 180, 1e-8);
|
|
|
|
|
}
|
|
|
|
|
@ -39,9 +39,9 @@ public class BoatInRaceTest {
|
|
|
|
|
@Test
|
|
|
|
|
public void calculateDueEastAzimuthReturns90() {
|
|
|
|
|
|
|
|
|
|
CompoundMark startCompoundMark = new CompoundMark(ORIGIN_COORDS);
|
|
|
|
|
CompoundMark endCompoundMark = new CompoundMark(new GPSCoordinate(0, 50));
|
|
|
|
|
Leg start = new Leg("Start", startCompoundMark, endCompoundMark, 0);
|
|
|
|
|
Marker startMarker = new Marker(ORIGIN_COORDS);
|
|
|
|
|
Marker endMarker = new Marker(new GPSCoordinate(0, 50));
|
|
|
|
|
Leg start = new Leg("Start", startMarker, endMarker, 0);
|
|
|
|
|
TEST_BOAT.setCurrentLeg(start);
|
|
|
|
|
assertEquals(TEST_BOAT.calculateAzimuth(), 90, 1e-8);
|
|
|
|
|
}
|
|
|
|
|
@ -49,9 +49,9 @@ public class BoatInRaceTest {
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void calculateDueWestAzimuthReturnsNegative90() {
|
|
|
|
|
CompoundMark startCompoundMark = new CompoundMark(ORIGIN_COORDS);
|
|
|
|
|
CompoundMark endCompoundMark = new CompoundMark(new GPSCoordinate(0, -50));
|
|
|
|
|
Leg start = new Leg("Start", startCompoundMark, endCompoundMark, 0);
|
|
|
|
|
Marker startMarker = new Marker(ORIGIN_COORDS);
|
|
|
|
|
Marker endMarker = new Marker(new GPSCoordinate(0, -50));
|
|
|
|
|
Leg start = new Leg("Start", startMarker, endMarker, 0);
|
|
|
|
|
TEST_BOAT.setCurrentLeg(start);
|
|
|
|
|
assertEquals(TEST_BOAT.calculateAzimuth(), -90, 1e-8);
|
|
|
|
|
|
|
|
|
|
@ -60,9 +60,9 @@ public class BoatInRaceTest {
|
|
|
|
|
@Test
|
|
|
|
|
public void calculateDueNorthHeadingReturns0() {
|
|
|
|
|
|
|
|
|
|
CompoundMark startCompoundMark = new CompoundMark(ORIGIN_COORDS);
|
|
|
|
|
CompoundMark endCompoundMark = new CompoundMark(new GPSCoordinate(50, 0));
|
|
|
|
|
Leg start = new Leg("Start", startCompoundMark, endCompoundMark, 0);
|
|
|
|
|
Marker startMarker = new Marker(ORIGIN_COORDS);
|
|
|
|
|
Marker endMarker = new Marker(new GPSCoordinate(50, 0));
|
|
|
|
|
Leg start = new Leg("Start", startMarker, endMarker, 0);
|
|
|
|
|
TEST_BOAT.setCurrentLeg(start);
|
|
|
|
|
assertEquals(TEST_BOAT.calculateHeading(), 0, 1e-8);
|
|
|
|
|
}
|
|
|
|
|
@ -70,27 +70,27 @@ public class BoatInRaceTest {
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void calculateDueEastHeadingReturns90() {
|
|
|
|
|
CompoundMark startCompoundMark = new CompoundMark(ORIGIN_COORDS);
|
|
|
|
|
CompoundMark endCompoundMark = new CompoundMark(new GPSCoordinate(0, 50));
|
|
|
|
|
Leg start = new Leg("Start", startCompoundMark, endCompoundMark, 0);
|
|
|
|
|
Marker startMarker = new Marker(ORIGIN_COORDS);
|
|
|
|
|
Marker endMarker = new Marker(new GPSCoordinate(0, 50));
|
|
|
|
|
Leg start = new Leg("Start", startMarker, endMarker, 0);
|
|
|
|
|
TEST_BOAT.setCurrentLeg(start);
|
|
|
|
|
assertEquals(TEST_BOAT.calculateHeading(), 90, 1e-8);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void calculateDueSouthHeadingReturns180() {
|
|
|
|
|
CompoundMark startCompoundMark = new CompoundMark(ORIGIN_COORDS);
|
|
|
|
|
CompoundMark endCompoundMark = new CompoundMark(new GPSCoordinate(-50, 0));
|
|
|
|
|
Leg start = new Leg("Start", startCompoundMark, endCompoundMark, 0);
|
|
|
|
|
Marker startMarker = new Marker(ORIGIN_COORDS);
|
|
|
|
|
Marker endMarker = new Marker(new GPSCoordinate(-50, 0));
|
|
|
|
|
Leg start = new Leg("Start", startMarker, endMarker, 0);
|
|
|
|
|
TEST_BOAT.setCurrentLeg(start);
|
|
|
|
|
assertEquals(TEST_BOAT.calculateHeading(), 180, 1e-8);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void calculateDueWestHeadingReturns270() {
|
|
|
|
|
CompoundMark startCompoundMark = new CompoundMark(ORIGIN_COORDS);
|
|
|
|
|
CompoundMark endCompoundMark = new CompoundMark(new GPSCoordinate(0, -50));
|
|
|
|
|
Leg start = new Leg("Start", startCompoundMark, endCompoundMark, 0);
|
|
|
|
|
Marker startMarker = new Marker(ORIGIN_COORDS);
|
|
|
|
|
Marker endMarker = new Marker(new GPSCoordinate(0, -50));
|
|
|
|
|
Leg start = new Leg("Start", startMarker, endMarker, 0);
|
|
|
|
|
TEST_BOAT.setCurrentLeg(start);
|
|
|
|
|
assertEquals(TEST_BOAT.calculateHeading(), 270, 1e-8);
|
|
|
|
|
}
|
|
|
|
|
@ -117,16 +117,16 @@ public class BoatInRaceTest {
|
|
|
|
|
BoatInRace boat = new BoatInRace("Test", 1, Color.ALICEBLUE, "tt");
|
|
|
|
|
|
|
|
|
|
// Construct leg of 0 degrees
|
|
|
|
|
CompoundMark startCompoundMark = new CompoundMark(ORIGIN_COORDS);
|
|
|
|
|
CompoundMark endCompoundMark = new CompoundMark(new GPSCoordinate(50, 0));
|
|
|
|
|
Leg leg0deg = new Leg("Start", startCompoundMark, endCompoundMark, 0);
|
|
|
|
|
Marker startMarker = new Marker(ORIGIN_COORDS);
|
|
|
|
|
Marker endMarker = new Marker(new GPSCoordinate(50, 0));
|
|
|
|
|
Leg leg0deg = new Leg("Start", startMarker, endMarker, 0);
|
|
|
|
|
boat.setCurrentLeg(leg0deg);
|
|
|
|
|
boat.setCurrentPosition(new GPSCoordinate(0, 0));
|
|
|
|
|
|
|
|
|
|
assertEquals(0, boat.calculateHeading(), 1e-8);
|
|
|
|
|
|
|
|
|
|
// Construct leg from wake - heading should be 180 degrees
|
|
|
|
|
Leg leg180deg = new Leg("Start", startCompoundMark, new CompoundMark(boat.getWake()), 0);
|
|
|
|
|
Leg leg180deg = new Leg("Start", startMarker, new Marker(boat.getWake()), 0);
|
|
|
|
|
boat.setCurrentLeg(leg180deg);
|
|
|
|
|
|
|
|
|
|
assertEquals(180, boat.calculateHeading(), 1e-8);
|
|
|
|
|
@ -138,9 +138,9 @@ public class BoatInRaceTest {
|
|
|
|
|
BoatInRace boat = new BoatInRace("Test", 10, Color.ALICEBLUE, "tt");
|
|
|
|
|
|
|
|
|
|
// Construct leg of 0 degrees at 0 N
|
|
|
|
|
CompoundMark startCompoundMark = new CompoundMark(ORIGIN_COORDS);
|
|
|
|
|
CompoundMark endCompoundMark = new CompoundMark(new GPSCoordinate(50, 0));
|
|
|
|
|
Leg leg0deg = new Leg("Start", startCompoundMark, endCompoundMark, 0);
|
|
|
|
|
Marker startMarker = new Marker(ORIGIN_COORDS);
|
|
|
|
|
Marker endMarker = new Marker(new GPSCoordinate(50, 0));
|
|
|
|
|
Leg leg0deg = new Leg("Start", startMarker, endMarker, 0);
|
|
|
|
|
boat.setCurrentLeg(leg0deg);
|
|
|
|
|
boat.setCurrentPosition(new GPSCoordinate(0, 0));
|
|
|
|
|
|
|
|
|
|
|