diff --git a/src/main/java/trap/report/ExcelHelper.java b/src/main/java/trap/report/ExcelHelper.java index 42da4d0..e997832 100644 --- a/src/main/java/trap/report/ExcelHelper.java +++ b/src/main/java/trap/report/ExcelHelper.java @@ -58,18 +58,25 @@ public static void setCurrentSeasonHeader(Sheet sheet) { public static void createFile(Workbook workbook) throws IOException { long start = System.currentTimeMillis(); + String filename = generateFilename(); + + logger.info("Creating file: {}", filename); + try (FileOutputStream fileOutputStream = new FileOutputStream(filename)) { + logger.info("Writing file..."); + workbook.write(fileOutputStream); + logger.info("File written successfully."); + } catch (IOException e) { + logger.error("Error writing file: {}", e.getMessage()); + throw e; + } + + logger.info("Created file in {} ms", System.currentTimeMillis() - start); + } + + private static String generateFilename() { var formatter = new SimpleDateFormat("yyyyMMddHHmmss"); var currentDate = formatter.format(new Date()); - var filename = "league-data-" + currentDate + ".xlsx"; - logger.info("Creating file"); - FileOutputStream fileOutputStream = new FileOutputStream(filename); - logger.info("Writing file"); - workbook.write(fileOutputStream); - logger.info("closing output stream"); - fileOutputStream.flush(); - fileOutputStream.close(); - logger.info("Created file {}", filename); - logger.info("Wrote the contents to a file in {} ms", System.currentTimeMillis() - start); + return "league-data-" + currentDate + ".xlsx"; } public static void addCleanData(Row row, RoundScore rowData) { diff --git a/src/main/java/trap/report/ReportHelper.java b/src/main/java/trap/report/ReportHelper.java index 50b0b91..8216155 100644 --- a/src/main/java/trap/report/ReportHelper.java +++ b/src/main/java/trap/report/ReportHelper.java @@ -99,16 +99,18 @@ public void generateExcelFile() throws Exception { } private List generateRoundScores() { - List allRoundScores; try { - allRoundScores = new ArrayList<>(); - for (var type : trapTypes) { - allRoundScores.addAll(generateRoundScores(type)); - } - - return allRoundScores; - } catch (IOException | CsvException e) { - throw new RuntimeException(e); + return Arrays.stream(trapTypes) + .flatMap(type -> { + try { + return generateRoundScores(type).stream(); + } catch (IOException | CsvException e) { + throw new RuntimeException("Error generating round scores for type: " + type, e); + } + }) + .toList(); + } catch (RuntimeException e) { + throw new RuntimeException("Error generating round scores", e); } } @@ -118,12 +120,41 @@ private Workbook getWorkbook() throws IOException { } private List generateRoundScores(String type) throws IOException, CsvException { - var reader = new CSVReader(new FileReader(type + ".csv")); - var roundScores = reader.readAll(); - roundScores.removeFirst(); - var roundScoresList = new ArrayList(); - roundScores.forEach(s -> roundScoresList.add(new RoundScore(Integer.parseInt(s[1]), trimString(s[2]), Integer.parseInt(s[3]), trimString(s[4]), trimString(s[5]), trimString(s[6]), trimString(s[7]).replace("Club", "Team"), trimString(s[8]), trimString(s[10]), trimString(s[11]), setStringToZero(s[12]), setStringToZero(s[13]), setStringToZero(s[14]), setStringToZero(s[15]), setStringToZero(s[16]), setStringToZero(s[17]), setStringToZero(s[18]), setStringToZero(s[19]), type))); - return roundScoresList; + try (var reader = new CSVReader(new FileReader(type + ".csv"))) { + var roundScores = reader.readAll(); + if (roundScores.isEmpty()) { + return new ArrayList<>(); // or handle as appropriate + } + roundScores.removeFirst(); // Remove the header row + + return roundScores.stream() + .map(s -> createRoundScore(s, type)) + .toList(); + } + } + + private RoundScore createRoundScore(String[] data, String type) { + return new RoundScore( + parseInteger(data[1]), + trimString(data[2]), + parseInteger(data[3]), + trimString(data[4]), + trimString(data[5]), + trimString(data[6]), + trimString(data[7]).replace("Club", "Team"), + trimString(data[8]), + trimString(data[10]), + trimString(data[11]), + setStringToZero(data[12]), + setStringToZero(data[13]), + setStringToZero(data[14]), + setStringToZero(data[15]), + setStringToZero(data[16]), + setStringToZero(data[17]), + setStringToZero(data[18]), + setStringToZero(data[19]), + type + ); } private void populateCleanData(Sheet sheet, List allRoundScores) { @@ -309,6 +340,7 @@ private List getTeamScoresByTotal(Map return teamScoresByTotal; } + // Team-Individual-Scores tab private void populateTeamIndividualData(Workbook workbook, String sheetName, List teamScoresByTotal) { var sheet = workbook.getSheet(sheetName); var startTime = System.currentTimeMillis(); @@ -351,8 +383,16 @@ private void populateAllIndividualData(Workbook workbook, String sheetName, Map< logger.info("Individual All Scores data populated in {} ms", System.currentTimeMillis() - trueStart); } + private int parseInteger(String number) { + try { + return Integer.parseInt(number); + } catch (NumberFormatException e) { + return 0; + } + } + private int setStringToZero(String number) { - return "".equals(number) ? 0 : Integer.parseInt(number); + return number.isEmpty() ? 0 : parseInteger(number); } private String trimString(String s) { diff --git a/src/main/java/trap/report/TrapHelper.java b/src/main/java/trap/report/TrapHelper.java index 2e03f84..8acda00 100644 --- a/src/main/java/trap/report/TrapHelper.java +++ b/src/main/java/trap/report/TrapHelper.java @@ -10,106 +10,146 @@ import java.util.HashSet; import java.util.List; import java.util.Map; +import java.util.Set; public class TrapHelper { + private static final Map roundCounts = determineEventsToCount(); - public Map> calculatePlayerRoundTotals(List roundScores) { - var playerRoundTotals = new HashMap>(); - for (var r : roundScores) { - playerRoundTotals.put(r.getUniqueName(), new ArrayList<>()); - } - for (var r : roundScores) { - var currentPlayerRoundTotal = playerRoundTotals.get(r.getUniqueName()); + public Map> calculatePlayerRoundTotals(List roundScores) { + Map> playerRoundTotals = new HashMap<>(); + + // Initialize map with empty lists for each unique player + roundScores.forEach(r -> playerRoundTotals.put(r.getUniqueName(), new ArrayList<>())); + + // Process each round score + for (RoundScore r : roundScores) { + List currentPlayerRoundTotal = playerRoundTotals.get(r.getUniqueName()); + + // If it's a single round, process round 1 and optionally round 2 if (singleRound(r.getType())) { - currentPlayerRoundTotal.add(new RoundTotal(r.getEventId(), r.getLocationId(), r.getTeam(), r.getAthlete(), r.getClassification(), r.getGender(), r.getRound1(), r.getType())); + addRound(currentPlayerRoundTotal, r, r.getRound1()); if (r.getRound2() > 0) { - currentPlayerRoundTotal.add(new RoundTotal(r.getEventId(), r.getLocationId(), r.getTeam(), r.getAthlete(), r.getClassification(), r.getGender(), r.getRound2(), r.getType())); + addRound(currentPlayerRoundTotal, r, r.getRound2()); } } else { - currentPlayerRoundTotal.add(new RoundTotal(r.getEventId(), r.getLocationId(), r.getTeam(), r.getAthlete(), r.getClassification(), r.getGender(), r.getRound1() + r.getRound2(), r.getType())); - if (r.getRound3() + r.getRound4() > 0) { - currentPlayerRoundTotal.add(new RoundTotal(r.getEventId(), r.getLocationId(), r.getTeam(), r.getAthlete(), r.getClassification(), r.getGender(), r.getRound3() + r.getRound4(), r.getType())); - if (r.getRound5() + r.getRound6() > 0) { - currentPlayerRoundTotal.add(new RoundTotal(r.getEventId(), r.getLocationId(), r.getTeam(), r.getAthlete(), r.getClassification(), r.getGender(), r.getRound5() + r.getRound6(), r.getType())); - if (r.getRound7() + r.getRound8() > 0) { - currentPlayerRoundTotal.add(new RoundTotal(r.getEventId(), r.getLocationId(), r.getTeam(), r.getAthlete(), r.getClassification(), r.getGender(), r.getRound7() + r.getRound8(), r.getType())); - } - } - } + addRound(currentPlayerRoundTotal, r, r.getRound1() + r.getRound2()); + addMultipleRounds(currentPlayerRoundTotal, r); } - playerRoundTotals.put(r.getUniqueName(), currentPlayerRoundTotal); } return playerRoundTotals; } - public Map> calculatePlayerIndividualTotal(List roundScores, Map> playerRoundTotals) { - var playerIndividualTotal = new HashMap>(); - for (var r : roundScores) { - playerIndividualTotal.put(r.getUniqueName(), new ArrayList<>()); + // Helper method to add individual rounds + private void addRound(List totals, RoundScore r, int total) { + totals.add(new RoundTotal(r.getEventId(), r.getLocationId(), r.getTeam(), r.getAthlete(), + r.getClassification(), r.getGender(), total, r.getType())); + } + + // Helper method to add rounds 3 to 8 if applicable + private void addMultipleRounds(List totals, RoundScore r) { + int[] additionalRounds = {r.getRound3() + r.getRound4(), r.getRound5() + r.getRound6(), r.getRound7() + r.getRound8()}; + + for (int round : additionalRounds) { + if (round > 0) { + addRound(totals, r, round); + } else { + break; // Stop processing once a round with zero total is found + } } - for (var playerRoundTotal : playerRoundTotals.values()) { - var roundsToCount = getRoundsToCount(playerRoundTotal.getFirst().getType()); - var indTotal = new ArrayList(); + } + + public Map> calculatePlayerIndividualTotal(List roundScores, Map> playerRoundTotals) { + Map> playerIndividualTotal = new HashMap<>(); + + // Initialize scores with empty lists + roundScores.forEach(r -> playerIndividualTotal.put(r.getUniqueName(), new ArrayList<>())); + + for (List playerRoundTotal : playerRoundTotals.values()) { + if (playerRoundTotal.isEmpty()) continue; + + String playerName = playerRoundTotal.getFirst().getUniqueName(); + int roundsToCount = getEventsToCount(playerRoundTotal.getFirst().getType()); + List indTotal = new ArrayList<>(); + + // Sort in descending order based on total score playerRoundTotal.sort(Comparator.comparingInt(RoundTotal::getTotal).reversed()); - for (var t : playerRoundTotal) { - if (indTotal.size() < (roundsToCount - 1)) { - indTotal.add(new IndividualTotal(t.getLocationId(), t.getTeam(), t.getAthlete(), t.getClassification(), t.getGender(), t.getTotal(), t.getType())); - } else { - var locationIds = new HashSet(); - indTotal.forEach(l -> locationIds.add(l.getLocationId())); - // if location doesn't already exist - if (!locationIds.contains(t.getLocationId())) { - indTotal.add(new IndividualTotal(t.getLocationId(), t.getTeam(), t.getAthlete(), t.getClassification(), t.getGender(), t.getTotal(), t.getType())); - break; - } - // if location isn't the same as the other 3 - if (locationIds.size() == 2 || locationIds.size() == 3) { - indTotal.add(new IndividualTotal(t.getLocationId(), t.getTeam(), t.getAthlete(), t.getClassification(), t.getGender(), t.getTotal(), t.getType())); - break; - } + + Set locationIds = new HashSet<>(); + for (RoundTotal t : playerRoundTotal) { + if (indTotal.size() < roundsToCount - 1) { + // Add round directly until we reach the number of rounds to count + indTotal.add(toIndividualTotal(t)); + locationIds.add(t.getLocationId()); + } else if (shouldAddRound(t, locationIds)) { + // Handle special case when location constraints are applied + indTotal.add(toIndividualTotal(t)); + break; } } - playerIndividualTotal.put(playerRoundTotal.getFirst().getUniqueName(), indTotal); + + playerIndividualTotal.put(playerName, indTotal); } return playerIndividualTotal; } - public Map calculatePlayerFinalTotal(Map> playerIndividualTotal) { - var playerFinalTotal = new HashMap(); - for (Map.Entry> entry : playerIndividualTotal.entrySet()) { - var key = entry.getKey(); - ArrayList value = entry.getValue(); - if (!value.isEmpty()) { - int total = 0; - for (var t : value) { - total += t.getTotal(); - } - playerFinalTotal.put(key, new IndividualTotal(0, value.getFirst().getTeam(), value.getFirst().getAthlete(), value.getFirst().getClassification(), value.getFirst().getGender(), total, value.getFirst().getType())); - } + private IndividualTotal toIndividualTotal(RoundTotal t) { + return new IndividualTotal(t.getLocationId(), t.getTeam(), t.getAthlete(), t.getClassification(), t.getGender(), t.getTotal(), t.getType()); + } + + // Method to determine if a round should be added based on location constraints + private boolean shouldAddRound( RoundTotal t, Set locationIds) { + int locationId = t.getLocationId(); + // Check if the location doesn't already exist + if (!locationIds.contains(locationId)) { + locationIds.add(locationId); + return true; } + // If there are already 2 or 3 unique locations, consider adding the round + return locationIds.size() == 2 || locationIds.size() == 3; + } + + public Map calculatePlayerFinalTotal(Map> playerIndividualTotals) { + var playerFinalTotals = new HashMap(); + playerIndividualTotals.forEach((key, totals) -> { + if (!totals.isEmpty()) { + var firstTotal = totals.getFirst(); + int totalScore = totals.stream().mapToInt(IndividualTotal::getTotal).sum(); + + playerFinalTotals.put(key, new IndividualTotal( + 0, + firstTotal.getTeam(), + firstTotal.getAthlete(), + firstTotal.getClassification(), + firstTotal.getGender(), + totalScore, + firstTotal.getType() + )); + } + }); - return playerFinalTotal; + return playerFinalTotals; } - private boolean singleRound(String roundType) { - return roundType.equals("clays") || roundType.equals("doubles") || roundType.equals("doublesskeet"); + public boolean singleRound(String roundType) { + Set validRounds = Set.of("clays", "doubles", "doublesskeet", "fivestand"); + return validRounds.contains(roundType); } - private static Map determineRoundsToCount() { + private static Map determineEventsToCount() { var roundCounts = new HashMap(); roundCounts.put("singles", 4); roundCounts.put("doubles", 4); roundCounts.put("handicap", 4); - roundCounts.put("skeet", 3); + roundCounts.put("skeet", 4); roundCounts.put("clays", 3); - roundCounts.put("fivestand", 3); - roundCounts.put("doublesskeet", 3); + roundCounts.put("fivestand", 4); + roundCounts.put("doublesskeet", 4); return roundCounts; } - public static int getRoundsToCount(String type) { - return Integer.parseInt(determineRoundsToCount().get(type).toString()); + public static int getEventsToCount(String type) { + return roundCounts.getOrDefault(type, 0); // Default to 0 if type not found } } diff --git a/src/test/java/trap/report/TrapHelperTest.java b/src/test/java/trap/report/TrapHelperTest.java index 99243d1..d5f2ad7 100644 --- a/src/test/java/trap/report/TrapHelperTest.java +++ b/src/test/java/trap/report/TrapHelperTest.java @@ -8,6 +8,8 @@ import java.util.List; import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertFalse; +import static org.junit.jupiter.api.Assertions.assertTrue; @SpringBootTest class TrapHelperTest { @@ -527,6 +529,7 @@ void skeetScoring3Locations() { roundScores.add(new RoundScore(16933, "Event 1", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 24, 24, 0, 0, 0, 0, 0, 0, "skeet")); roundScores.add(new RoundScore(16940, "Event 2", 50, "Location 2", "2022-09-11", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 23, 22, 0, 0, 0, 0, 0, 0, "skeet")); roundScores.add(new RoundScore(17159, "Event 4", 986, "Location 4", "2022-09-24", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 21, 23, 0, 0, 0, 0, 0, 0, "skeet")); + roundScores.add(new RoundScore(17159, "Event 4", 986, "Location 4", "2022-09-24", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 21, 23, 0, 0, 0, 0, 0, 0, "skeet")); var playerRoundTotals = trapHelper.calculatePlayerRoundTotals(roundScores); var playerIndividualTotal = trapHelper.calculatePlayerIndividualTotal(roundScores, playerRoundTotals); @@ -538,7 +541,7 @@ void skeetScoring3Locations() { assertEquals("Sam LaPorta", playerFinalTotal.get(player1.getUniqueName()).getAthlete()); assertEquals("Senior/Varsity", playerFinalTotal.get(player1.getUniqueName()).getClassification()); assertEquals("M", playerFinalTotal.get(player1.getUniqueName()).getGender()); - assertEquals(137, playerFinalTotal.get(player1.getUniqueName()).getTotal()); + assertEquals(181, playerFinalTotal.get(player1.getUniqueName()).getTotal()); assertEquals("skeet", playerFinalTotal.get(player1.getUniqueName()).getType()); } @@ -561,7 +564,7 @@ void skeetScoring2Locations() { assertEquals("Sam LaPorta", playerFinalTotal.get(player1.getUniqueName()).getAthlete()); assertEquals("Senior/Varsity", playerFinalTotal.get(player1.getUniqueName()).getClassification()); assertEquals("M", playerFinalTotal.get(player1.getUniqueName()).getGender()); - assertEquals(137, playerFinalTotal.get(player1.getUniqueName()).getTotal()); + assertEquals(179, playerFinalTotal.get(player1.getUniqueName()).getTotal()); assertEquals("skeet", playerFinalTotal.get(player1.getUniqueName()).getType()); } @@ -587,7 +590,7 @@ void skeetScoring2LocationsWithHigherScoresInOneLocation() { assertEquals("Sam LaPorta", playerFinalTotal.get(player1.getUniqueName()).getAthlete()); assertEquals("Senior/Varsity", playerFinalTotal.get(player1.getUniqueName()).getClassification()); assertEquals("M", playerFinalTotal.get(player1.getUniqueName()).getGender()); - assertEquals(141, playerFinalTotal.get(player1.getUniqueName()).getTotal()); + assertEquals(189, playerFinalTotal.get(player1.getUniqueName()).getTotal()); assertEquals("skeet", playerFinalTotal.get(player1.getUniqueName()).getType()); } @@ -595,9 +598,9 @@ void skeetScoring2LocationsWithHigherScoresInOneLocation() { void claysScoring3Locations() { var roundScores = new ArrayList(); - roundScores.add(new RoundScore(16933, "Event 1", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 23, 0, 0, 0, 0, 0, 0, "clays")); - roundScores.add(new RoundScore(16940, "Event 2", 50, "Location 2", "2022-09-11", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 45, 22, 0, 0, 0, 0, 0, 0, "clays")); - roundScores.add(new RoundScore(17159, "Event 4", 123, "Location 4", "2022-09-24", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 44, 23, 0, 0, 0, 0, 0, 0, "clays")); + roundScores.add(new RoundScore(16933, "Event 1", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 96, 23, 0, 0, 0, 0, 0, 0, "clays")); + roundScores.add(new RoundScore(16940, "Event 2", 50, "Location 2", "2022-09-11", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 93, 22, 0, 0, 0, 0, 0, 0, "clays")); + roundScores.add(new RoundScore(17159, "Event 4", 123, "Location 4", "2022-09-24", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 88, 23, 0, 0, 0, 0, 0, 0, "clays")); var playerRoundTotals = trapHelper.calculatePlayerRoundTotals(roundScores); var playerIndividualTotal = trapHelper.calculatePlayerIndividualTotal(roundScores, playerRoundTotals); @@ -609,7 +612,7 @@ void claysScoring3Locations() { assertEquals("Sam LaPorta", playerFinalTotal.get(player1.getUniqueName()).getAthlete()); assertEquals("Senior/Varsity", playerFinalTotal.get(player1.getUniqueName()).getClassification()); assertEquals("M", playerFinalTotal.get(player1.getUniqueName()).getGender()); - assertEquals(137, playerFinalTotal.get(player1.getUniqueName()).getTotal()); + assertEquals(277, playerFinalTotal.get(player1.getUniqueName()).getTotal()); assertEquals("clays", playerFinalTotal.get(player1.getUniqueName()).getType()); } @@ -617,13 +620,13 @@ void claysScoring3Locations() { void claysScoring3LocationsWithHigherScoresInOneLocation() { var roundScores = new ArrayList(); - roundScores.add(new RoundScore(16933, "Event 1", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 44, 0, 0, 0, 0, 0, 0, "clays")); - roundScores.add(new RoundScore(16943, "Event 2", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 44, 0, 0, 0, 0, 0, 0, "clays")); - roundScores.add(new RoundScore(16953, "Event 3", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 44, 0, 0, 0, 0, 0, 0, "clays")); - roundScores.add(new RoundScore(16963, "Event 4", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 44, 0, 0, 0, 0, 0, 0, "clays")); - roundScores.add(new RoundScore(16973, "Event 5", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 44, 0, 0, 0, 0, 0, 0, "clays")); - roundScores.add(new RoundScore(16940, "Event 6", 50, "Location 2", "2022-09-11", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 45, 22, 0, 0, 0, 0, 0, 0, "clays")); - roundScores.add(new RoundScore(18168, "Event 7", 12, "Location 6", "2023-04-09", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 44, 23, 0, 0, 0, 0, 0, 0, "clays")); + roundScores.add(new RoundScore(16933, "Event 1", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 96, 88, 0, 0, 0, 0, 0, 0, "clays")); + roundScores.add(new RoundScore(16943, "Event 2", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 96, 88, 0, 0, 0, 0, 0, 0, "clays")); + roundScores.add(new RoundScore(16953, "Event 3", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 96, 88, 0, 0, 0, 0, 0, 0, "clays")); + roundScores.add(new RoundScore(16963, "Event 4", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 96, 88, 0, 0, 0, 0, 0, 0, "clays")); + roundScores.add(new RoundScore(16973, "Event 5", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 96, 88, 0, 0, 0, 0, 0, 0, "clays")); + roundScores.add(new RoundScore(16940, "Event 6", 50, "Location 2", "2022-09-11", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 90, 22, 0, 0, 0, 0, 0, 0, "clays")); + roundScores.add(new RoundScore(18168, "Event 7", 12, "Location 6", "2023-04-09", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 88, 23, 0, 0, 0, 0, 0, 0, "clays")); var playerRoundTotals = trapHelper.calculatePlayerRoundTotals(roundScores); var playerIndividualTotal = trapHelper.calculatePlayerIndividualTotal(roundScores, playerRoundTotals); @@ -635,16 +638,40 @@ void claysScoring3LocationsWithHigherScoresInOneLocation() { assertEquals("Sam LaPorta", playerFinalTotal.get(player1.getUniqueName()).getAthlete()); assertEquals("Senior/Varsity", playerFinalTotal.get(player1.getUniqueName()).getClassification()); assertEquals("M", playerFinalTotal.get(player1.getUniqueName()).getGender()); - assertEquals(141, playerFinalTotal.get(player1.getUniqueName()).getTotal()); + assertEquals(282, playerFinalTotal.get(player1.getUniqueName()).getTotal()); assertEquals("clays", playerFinalTotal.get(player1.getUniqueName()).getType()); } + @Test + void doublesskeetScoring4Locations() { + var roundScores = new ArrayList(); + + roundScores.add(new RoundScore(16933, "Event 1", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 23, 0, 0, 0, 0, 0, 0, "doublesskeet")); + roundScores.add(new RoundScore(16940, "Event 2", 50, "Location 2", "2022-09-11", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 45, 22, 0, 0, 0, 0, 0, 0, "doublesskeet")); + roundScores.add(new RoundScore(17159, "Event 3", 123, "Location 3", "2022-09-24", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 44, 23, 0, 0, 0, 0, 0, 0, "doublesskeet")); + roundScores.add(new RoundScore(17159, "Event 4", 24, "Location 4", "2022-09-24", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 44, 23, 0, 0, 0, 0, 0, 0, "doublesskeet")); + + var playerRoundTotals = trapHelper.calculatePlayerRoundTotals(roundScores); + var playerIndividualTotal = trapHelper.calculatePlayerIndividualTotal(roundScores, playerRoundTotals); + var playerFinalTotal = trapHelper.calculatePlayerFinalTotal(playerIndividualTotal); + + var player1 = roundScores.getFirst(); + assertEquals(0, playerFinalTotal.get(player1.getUniqueName()).getLocationId()); + assertEquals("Team Name", playerFinalTotal.get(player1.getUniqueName()).getTeam()); + assertEquals("Sam LaPorta", playerFinalTotal.get(player1.getUniqueName()).getAthlete()); + assertEquals("Senior/Varsity", playerFinalTotal.get(player1.getUniqueName()).getClassification()); + assertEquals("M", playerFinalTotal.get(player1.getUniqueName()).getGender()); + assertEquals(181, playerFinalTotal.get(player1.getUniqueName()).getTotal()); + assertEquals("doublesskeet", playerFinalTotal.get(player1.getUniqueName()).getType()); + } + @Test void doublesskeetScoring3Locations() { var roundScores = new ArrayList(); roundScores.add(new RoundScore(16933, "Event 1", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 23, 0, 0, 0, 0, 0, 0, "doublesskeet")); roundScores.add(new RoundScore(16940, "Event 2", 50, "Location 2", "2022-09-11", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 45, 22, 0, 0, 0, 0, 0, 0, "doublesskeet")); + roundScores.add(new RoundScore(17159, "Event 3", 123, "Location 3", "2022-09-24", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 44, 23, 0, 0, 0, 0, 0, 0, "doublesskeet")); roundScores.add(new RoundScore(17159, "Event 4", 123, "Location 4", "2022-09-24", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 44, 23, 0, 0, 0, 0, 0, 0, "doublesskeet")); var playerRoundTotals = trapHelper.calculatePlayerRoundTotals(roundScores); @@ -657,7 +684,30 @@ void doublesskeetScoring3Locations() { assertEquals("Sam LaPorta", playerFinalTotal.get(player1.getUniqueName()).getAthlete()); assertEquals("Senior/Varsity", playerFinalTotal.get(player1.getUniqueName()).getClassification()); assertEquals("M", playerFinalTotal.get(player1.getUniqueName()).getGender()); - assertEquals(137, playerFinalTotal.get(player1.getUniqueName()).getTotal()); + assertEquals(181, playerFinalTotal.get(player1.getUniqueName()).getTotal()); + assertEquals("doublesskeet", playerFinalTotal.get(player1.getUniqueName()).getType()); + } + + @Test + void doublesskeetScoring2Locations() { + var roundScores = new ArrayList(); + + roundScores.add(new RoundScore(16933, "Event 1", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 23, 0, 0, 0, 0, 0, 0, "doublesskeet")); + roundScores.add(new RoundScore(16940, "Event 2", 986, "Location 2", "2022-09-11", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 45, 22, 0, 0, 0, 0, 0, 0, "doublesskeet")); + roundScores.add(new RoundScore(17159, "Event 3", 123, "Location 3", "2022-09-24", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 44, 23, 0, 0, 0, 0, 0, 0, "doublesskeet")); + roundScores.add(new RoundScore(17159, "Event 4", 123, "Location 4", "2022-09-24", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 44, 23, 0, 0, 0, 0, 0, 0, "doublesskeet")); + + var playerRoundTotals = trapHelper.calculatePlayerRoundTotals(roundScores); + var playerIndividualTotal = trapHelper.calculatePlayerIndividualTotal(roundScores, playerRoundTotals); + var playerFinalTotal = trapHelper.calculatePlayerFinalTotal(playerIndividualTotal); + + var player1 = roundScores.getFirst(); + assertEquals(0, playerFinalTotal.get(player1.getUniqueName()).getLocationId()); + assertEquals("Team Name", playerFinalTotal.get(player1.getUniqueName()).getTeam()); + assertEquals("Sam LaPorta", playerFinalTotal.get(player1.getUniqueName()).getAthlete()); + assertEquals("Senior/Varsity", playerFinalTotal.get(player1.getUniqueName()).getClassification()); + assertEquals("M", playerFinalTotal.get(player1.getUniqueName()).getGender()); + assertEquals(181, playerFinalTotal.get(player1.getUniqueName()).getTotal()); assertEquals("doublesskeet", playerFinalTotal.get(player1.getUniqueName()).getType()); } @@ -683,7 +733,7 @@ void doublesskeetScoring3LocationsWithHigherScoresInOneLocation() { assertEquals("Sam LaPorta", playerFinalTotal.get(player1.getUniqueName()).getAthlete()); assertEquals("Senior/Varsity", playerFinalTotal.get(player1.getUniqueName()).getClassification()); assertEquals("M", playerFinalTotal.get(player1.getUniqueName()).getGender()); - assertEquals(141, playerFinalTotal.get(player1.getUniqueName()).getTotal()); + assertEquals(189, playerFinalTotal.get(player1.getUniqueName()).getTotal()); assertEquals("doublesskeet", playerFinalTotal.get(player1.getUniqueName()).getType()); } @@ -691,9 +741,10 @@ void doublesskeetScoring3LocationsWithHigherScoresInOneLocation() { void fivestandScoring3Locations() { var roundScores = new ArrayList(); - roundScores.add(new RoundScore(16933, "Event 1", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 25, 23, 0, 0, 0, 0, 0, 0, "fivestand")); - roundScores.add(new RoundScore(16940, "Event 2", 50, "Location 2", "2022-09-11", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 23, 22, 0, 0, 0, 0, 0, 0, "fivestand")); - roundScores.add(new RoundScore(17159, "Event 4", 123, "Location 4", "2022-09-24", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 21, 23, 0, 0, 0, 0, 0, 0, "fivestand")); + roundScores.add(new RoundScore(16933, "Event 1", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 23, 0, 0, 0, 0, 0, 0, "fivestand")); + roundScores.add(new RoundScore(16940, "Event 2", 50, "Location 2", "2022-09-11", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 45, 22, 0, 0, 0, 0, 0, 0, "fivestand")); + roundScores.add(new RoundScore(17159, "Event 3", 123, "Location 3", "2022-09-24", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 44, 23, 0, 0, 0, 0, 0, 0, "fivestand")); + roundScores.add(new RoundScore(17159, "Event 4", 123, "Location 4", "2022-09-24", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 50, 23, 0, 0, 0, 0, 0, 0, "fivestand")); var playerRoundTotals = trapHelper.calculatePlayerRoundTotals(roundScores); var playerIndividualTotal = trapHelper.calculatePlayerIndividualTotal(roundScores, playerRoundTotals); @@ -705,7 +756,7 @@ void fivestandScoring3Locations() { assertEquals("Sam LaPorta", playerFinalTotal.get(player1.getUniqueName()).getAthlete()); assertEquals("Senior/Varsity", playerFinalTotal.get(player1.getUniqueName()).getClassification()); assertEquals("M", playerFinalTotal.get(player1.getUniqueName()).getGender()); - assertEquals(137, playerFinalTotal.get(player1.getUniqueName()).getTotal()); + assertEquals(187, playerFinalTotal.get(player1.getUniqueName()).getTotal()); assertEquals("fivestand", playerFinalTotal.get(player1.getUniqueName()).getType()); } @@ -713,13 +764,13 @@ void fivestandScoring3Locations() { void fivestandScoring3LocationsWithHigherScoresInOneLocation() { var roundScores = new ArrayList(); - roundScores.add(new RoundScore(16933, "Event 1", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 24, 24, 0, 0, 0, 0, 0, 0, "fivestand")); - roundScores.add(new RoundScore(16943, "Event 2", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 24, 24, 0, 0, 0, 0, 0, 0, "fivestand")); - roundScores.add(new RoundScore(16953, "Event 3", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 24, 24, 0, 0, 0, 0, 0, 0, "fivestand")); - roundScores.add(new RoundScore(16963, "Event 4", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 24, 24, 0, 0, 0, 0, 0, 0, "fivestand")); - roundScores.add(new RoundScore(16973, "Event 5", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 24, 24, 0, 0, 0, 0, 0, 0, "fivestand")); - roundScores.add(new RoundScore(16940, "Event 6", 50, "Location 2", "2022-09-11", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 23, 22, 0, 0, 0, 0, 0, 0, "fivestand")); - roundScores.add(new RoundScore(18168, "Event 7", 12, "Location 6", "2023-04-09", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 21, 23, 0, 0, 0, 0, 0, 0, "fivestand")); + roundScores.add(new RoundScore(16933, "Event 1", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 24, 0, 0, 0, 0, 0, 0, "fivestand")); + roundScores.add(new RoundScore(16943, "Event 2", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 24, 0, 0, 0, 0, 0, 0, "fivestand")); + roundScores.add(new RoundScore(16953, "Event 3", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 24, 0, 0, 0, 0, 0, 0, "fivestand")); + roundScores.add(new RoundScore(16963, "Event 4", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 24, 0, 0, 0, 0, 0, 0, "fivestand")); + roundScores.add(new RoundScore(16973, "Event 5", 986, "Location 1", "2022-09-03", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 48, 24, 0, 0, 0, 0, 0, 0, "fivestand")); + roundScores.add(new RoundScore(16940, "Event 6", 50, "Location 2", "2022-09-11", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 45, 22, 0, 0, 0, 0, 0, 0, "fivestand")); + roundScores.add(new RoundScore(18168, "Event 7", 12, "Location 6", "2023-04-09", "Squad Name", "Team Name", "Sam LaPorta", "Senior/Varsity", "M", 44, 23, 0, 0, 0, 0, 0, 0, "fivestand")); var playerRoundTotals = trapHelper.calculatePlayerRoundTotals(roundScores); var playerIndividualTotal = trapHelper.calculatePlayerIndividualTotal(roundScores, playerRoundTotals); @@ -731,19 +782,32 @@ void fivestandScoring3LocationsWithHigherScoresInOneLocation() { assertEquals("Sam LaPorta", playerFinalTotal.get(player1.getUniqueName()).getAthlete()); assertEquals("Senior/Varsity", playerFinalTotal.get(player1.getUniqueName()).getClassification()); assertEquals("M", playerFinalTotal.get(player1.getUniqueName()).getGender()); - assertEquals(141, playerFinalTotal.get(player1.getUniqueName()).getTotal()); + assertEquals(189, playerFinalTotal.get(player1.getUniqueName()).getTotal()); assertEquals("fivestand", playerFinalTotal.get(player1.getUniqueName()).getType()); } + @Test + void eventsToCount() { + assertEquals(4, TrapHelper.getEventsToCount("singles")); + assertEquals(4, TrapHelper.getEventsToCount("doubles")); + assertEquals(4, TrapHelper.getEventsToCount("handicap")); + assertEquals(4, TrapHelper.getEventsToCount("skeet")); + assertEquals(4, TrapHelper.getEventsToCount("fivestand")); + assertEquals(4, TrapHelper.getEventsToCount("doublesskeet")); + + assertEquals(3, TrapHelper.getEventsToCount("clays")); + } + @Test void roundsToCount() { - assertEquals(4, TrapHelper.getRoundsToCount("singles")); - assertEquals(4, TrapHelper.getRoundsToCount("doubles")); - assertEquals(4, TrapHelper.getRoundsToCount("handicap")); - - assertEquals(3, TrapHelper.getRoundsToCount("skeet")); - assertEquals(3, TrapHelper.getRoundsToCount("clays")); - assertEquals(3, TrapHelper.getRoundsToCount("fivestand")); - assertEquals(3, TrapHelper.getRoundsToCount("doublesskeet")); + assertTrue(trapHelper.singleRound("clays")); + assertTrue(trapHelper.singleRound("doubles")); + assertTrue(trapHelper.singleRound("fivestand")); + assertTrue(trapHelper.singleRound("doublesskeet")); + + assertFalse(trapHelper.singleRound("singles")); + assertFalse(trapHelper.singleRound("handicap")); + assertFalse(trapHelper.singleRound("skeet")); + } }